blob: a77cb24975bb365c0e19d57882b9b93776358403 [file] [log] [blame]
Marian Balakowicz78b123c2006-05-09 11:54:44 +02001/*
2 * Configuation settings for the Freescale M5271EVB
3 *
4 * Based on MC5272C3 and r5200 board configs
5 * (C) Copyright 2006 Lab X Technologies <zachary.landau@labxtechnologies.com>
6 * (C) Copyright 2003 Josef Baumgartner <josef.baumgartner@telex.de>
7 *
Wolfgang Denk1a459662013-07-08 09:37:19 +02008 * SPDX-License-Identifier: GPL-2.0+
Marian Balakowicz78b123c2006-05-09 11:54:44 +02009 */
10
11/*
12 * board/config.h - configuration options, board specific
13 */
14
15#ifndef _M5271EVB_H
16#define _M5271EVB_H
17
Marian Balakowicz78b123c2006-05-09 11:54:44 +020018/*
19 * High Level Configuration Options (easy to change)
20 */
21#define CONFIG_MCF52x2 /* define processor family */
22#define CONFIG_M5271 /* define processor type */
23#define CONFIG_M5271EVB /* define board type */
24
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050025#define CONFIG_MCFTMR
Marian Balakowicz78b123c2006-05-09 11:54:44 +020026
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050027#define CONFIG_MCFUART
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020028#define CONFIG_SYS_UART_PORT (0)
TsiChung Liew79e07992008-08-15 16:50:07 +000029#define CONFIG_BAUDRATE 115200
Marian Balakowicz78b123c2006-05-09 11:54:44 +020030
31#undef CONFIG_WATCHDOG /* disable watchdog */
32
Marian Balakowicz78b123c2006-05-09 11:54:44 +020033/* Configuration for environment
34 * Environment is embedded in u-boot in the second sector of the flash
35 */
36#ifndef CONFIG_MONITOR_IS_IN_RAM
Jean-Christophe PLAGNIOL-VILLARD0e8d1582008-09-10 22:48:06 +020037#define CONFIG_ENV_OFFSET 0x4000
Marian Balakowicz78b123c2006-05-09 11:54:44 +020038#else
Jean-Christophe PLAGNIOL-VILLARD0e8d1582008-09-10 22:48:06 +020039#define CONFIG_ENV_ADDR 0xffe04000
Wolfgang Denk67c31032007-09-16 17:10:04 +020040#endif
Jean-Christophe PLAGNIOL-VILLARD0e8d1582008-09-10 22:48:06 +020041#define CONFIG_ENV_SECT_SIZE 0x2000
Jean-Christophe PLAGNIOL-VILLARD5a1aceb2008-09-10 22:48:04 +020042#define CONFIG_ENV_IS_IN_FLASH 1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020043#define CONFIG_SYS_USE_PPCENV /* Environment embedded in sect .ppcenv */
Marian Balakowicz78b123c2006-05-09 11:54:44 +020044
Jon Loeliger8353e132007-07-08 14:14:17 -050045/*
Jon Loeliger659e2f62007-07-10 09:10:49 -050046 * BOOTP options
47 */
48#define CONFIG_BOOTP_BOOTFILESIZE
49#define CONFIG_BOOTP_BOOTPATH
50#define CONFIG_BOOTP_GATEWAY
51#define CONFIG_BOOTP_HOSTNAME
52
Jon Loeliger659e2f62007-07-10 09:10:49 -050053/*
Jon Loeliger8353e132007-07-08 14:14:17 -050054 * Command line configuration.
55 */
56#include <config_cmd_default.h>
Marian Balakowicz78b123c2006-05-09 11:54:44 +020057
TsiChung Liewdd9f0542010-03-11 22:12:53 -060058#define CONFIG_CMD_CACHE
Jon Loeliger8353e132007-07-08 14:14:17 -050059#define CONFIG_CMD_PING
60#define CONFIG_CMD_NET
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050061#define CONFIG_CMD_MII
62#define CONFIG_CMD_ELF
63#define CONFIG_CMD_FLASH
64#define CONFIG_CMD_I2C
65#define CONFIG_CMD_MEMORY
66#define CONFIG_CMD_MISC
Jon Loeliger8353e132007-07-08 14:14:17 -050067
68#undef CONFIG_CMD_LOADS
Richard Retanubun8706ef32009-01-23 14:07:05 -050069#define CONFIG_CMD_LOADB
70#define CONFIG_CMDLINE_EDITING 1 /* enables command line history */
71#define CONFIG_SYS_HUSH_PARSER /* Use the HUSH parser */
Jon Loeliger8353e132007-07-08 14:14:17 -050072
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050073#define CONFIG_MCFFEC
74#ifdef CONFIG_MCFFEC
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050075# define CONFIG_MII 1
TsiChung Liew0f3ba7e2008-03-30 01:22:13 -050076# define CONFIG_MII_INIT 1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020077# define CONFIG_SYS_DISCOVER_PHY
78# define CONFIG_SYS_RX_ETH_BUFFER 8
79# define CONFIG_SYS_FAULT_ECHO_LINK_DOWN
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050080
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020081# define CONFIG_SYS_FEC0_PINMUX 0
82# define CONFIG_SYS_FEC0_MIIBASE CONFIG_SYS_FEC0_IOBASE
Wolfgang Denk53677ef2008-05-20 16:00:29 +020083# define MCFFEC_TOUT_LOOP 50000
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020084/* If CONFIG_SYS_DISCOVER_PHY is not defined - hardcoded */
85# ifndef CONFIG_SYS_DISCOVER_PHY
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050086# define FECDUPLEX FULL
87# define FECSPEED _100BASET
88# else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020089# ifndef CONFIG_SYS_FAULT_ECHO_LINK_DOWN
90# define CONFIG_SYS_FAULT_ECHO_LINK_DOWN
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050091# endif
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020092# endif /* CONFIG_SYS_DISCOVER_PHY */
TsiChungLiewf28e1bd2007-08-15 20:32:06 -050093#endif
94
95/* I2C */
Heiko Schocher00f792e2012-10-24 13:48:22 +020096#define CONFIG_SYS_I2C
97#define CONFIG_SYS_I2C_FSL
98#define CONFIG_SYS_FSL_I2C_SPEED 80000
99#define CONFIG_SYS_FSL_I2C_SLAVE 0x7F
100#define CONFIG_SYS_FSL_I2C_OFFSET 0x00000300
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200101#define CONFIG_SYS_IMMR CONFIG_SYS_MBAR
TsiChungLiewf28e1bd2007-08-15 20:32:06 -0500102
Richard Retanubun8706ef32009-01-23 14:07:05 -0500103#define CONFIG_BOOTDELAY 1 /* autoboot after 1 seconds */
TsiChungLiewf28e1bd2007-08-15 20:32:06 -0500104#define CONFIG_BOOTFILE "u-boot.bin"
105#ifdef CONFIG_MCFFEC
106# define CONFIG_NET_RETRY_COUNT 5
107# define CONFIG_ETHADDR 00:e0:0c:bc:e5:60
108# define CONFIG_IPADDR 192.162.1.2
109# define CONFIG_NETMASK 255.255.255.0
110# define CONFIG_SERVERIP 192.162.1.1
111# define CONFIG_GATEWAYIP 192.162.1.1
112# define CONFIG_OVERWRITE_ETHADDR_ONCE
113#endif /* FEC_ENET */
114
Richard Retanubun8706ef32009-01-23 14:07:05 -0500115#define CONFIG_HOSTNAME M5271EVB
TsiChungLiewf28e1bd2007-08-15 20:32:06 -0500116#define CONFIG_EXTRA_ENV_SETTINGS \
117 "netdev=eth0\0" \
118 "loadaddr=10000\0" \
Richard Retanubun8706ef32009-01-23 14:07:05 -0500119 "uboot=u-boot.bin\0" \
120 "load=tftp $loadaddr $uboot\0" \
TsiChungLiewf28e1bd2007-08-15 20:32:06 -0500121 "upd=run load; run prog\0" \
Richard Retanubun8706ef32009-01-23 14:07:05 -0500122 "prog=prot off ffe00000 ffe3ffff;" \
123 "era ffe00000 ffe3ffff;" \
124 "cp.b $loadaddr ffe00000 $filesize;" \
TsiChungLiewf28e1bd2007-08-15 20:32:06 -0500125 "save\0" \
126 ""
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200127
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200128#define CONFIG_SYS_PROMPT "=> "
129#define CONFIG_SYS_LONGHELP /* undef to save memory */
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200130
Jon Loeliger8353e132007-07-08 14:14:17 -0500131#if defined(CONFIG_CMD_KGDB)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200132#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200133#else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200134#define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200135#endif
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200136#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) /* Print Buffer Size */
137#define CONFIG_SYS_MAXARGS 16 /* max number of command args */
138#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot Argument Buffer Size */
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200139
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200140#define CONFIG_SYS_LOAD_ADDR 0x00100000
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200141
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200142#define CONFIG_SYS_MEMTEST_START 0x400
143#define CONFIG_SYS_MEMTEST_END 0x380000
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200144
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200145#define CONFIG_SYS_HZ 1000000
Richard Retanubun8706ef32009-01-23 14:07:05 -0500146
147/* Clock configuration
148 * The external oscillator is a 25.000 MHz
149 * CONFIG_SYS_CLK for ColdFire V2 sets cpu_clk (not bus_clk)
150 * bus_clk = (cpu_clk/2) (fixed ratio)
151 *
152 * If CONFIG_SYS_CLK is changed. the CONFIG_SYS_MCF_SYNCR must be updated to
153 * match the new clock speed. Max cpu_clk is 150 MHz.
154 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200155#define CONFIG_SYS_CLK 100000000
Richard Retanubun8706ef32009-01-23 14:07:05 -0500156#define CONFIG_SYS_MCF_SYNCR (MCF_SYNCR_MFD_4X | MCF_SYNCR_RFD_DIV1)
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200157
158/*
159 * Low Level Configuration Settings
160 * (address mappings, register initial values, etc.)
161 * You should know what you are doing if you make changes here.
162 */
163
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200164#define CONFIG_SYS_MBAR 0x40000000 /* Register Base Addrs */
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200165
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200166/*
167 * Definitions for initial stack pointer and data area (in DPRAM)
168 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200169#define CONFIG_SYS_INIT_RAM_ADDR 0x20000000
Wolfgang Denk553f0982010-10-26 13:32:32 +0200170#define CONFIG_SYS_INIT_RAM_SIZE 0x1000 /* Size of used area in internal SRAM */
Wolfgang Denk25ddd1f2010-10-26 14:34:52 +0200171#define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200172#define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200173
174/*
175 * Start addresses for the final memory configuration
176 * (Set up by the startup code)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200177 * Please note that CONFIG_SYS_SDRAM_BASE _must_ start at 0
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200178 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200179#define CONFIG_SYS_SDRAM_BASE 0x00000000
180#define CONFIG_SYS_SDRAM_SIZE 16 /* SDRAM size in MB */
181#define CONFIG_SYS_FLASH_BASE 0xffe00000
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200182
183#ifdef CONFIG_MONITOR_IS_IN_RAM
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200184#define CONFIG_SYS_MONITOR_BASE 0x20000
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200185#else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200186#define CONFIG_SYS_MONITOR_BASE (CONFIG_SYS_FLASH_BASE + 0x400)
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200187#endif
188
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200189#define CONFIG_SYS_MONITOR_LEN 0x40000
190#define CONFIG_SYS_MALLOC_LEN (256 << 10)
191#define CONFIG_SYS_BOOTPARAMS_LEN (64*1024)
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200192
193/*
194 * For booting Linux, the board info and command line data
195 * have to be in the first 8 MB of memory, since this is
196 * the maximum mapped by the Linux kernel during initialization ??
197 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200198#define CONFIG_SYS_BOOTMAPSZ (CONFIG_SYS_SDRAM_BASE + (CONFIG_SYS_SDRAM_SIZE << 20))
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200199
200/* FLASH organization */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200201#define CONFIG_SYS_MAX_FLASH_BANKS 1 /* max number of memory banks */
202#define CONFIG_SYS_MAX_FLASH_SECT 11 /* max number of sectors on one chip */
203#define CONFIG_SYS_FLASH_ERASE_TOUT 1000
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200204
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200205#define CONFIG_SYS_FLASH_CFI 1
Jean-Christophe PLAGNIOL-VILLARD00b18832008-08-13 01:40:42 +0200206#define CONFIG_FLASH_CFI_DRIVER 1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200207#define CONFIG_SYS_FLASH_SIZE 0x200000
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200208
209/* Cache Configuration */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200210#define CONFIG_SYS_CACHELINE_SIZE 16
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200211
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600212#define ICACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \
Wolfgang Denk553f0982010-10-26 13:32:32 +0200213 CONFIG_SYS_INIT_RAM_SIZE - 8)
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600214#define DCACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \
Wolfgang Denk553f0982010-10-26 13:32:32 +0200215 CONFIG_SYS_INIT_RAM_SIZE - 4)
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600216#define CONFIG_SYS_ICACHE_INV (CF_CACR_CINV | CF_CACR_INVI)
217#define CONFIG_SYS_CACHE_ACR0 (CONFIG_SYS_SDRAM_BASE | \
218 CF_ADDRMASK(CONFIG_SYS_SDRAM_SIZE) | \
219 CF_ACR_EN | CF_ACR_SM_ALL)
220#define CONFIG_SYS_CACHE_ICACR (CF_CACR_CENB | CF_CACR_CINV | \
221 CF_CACR_DISD | CF_CACR_INVI | \
222 CF_CACR_CEIB | CF_CACR_DCM | \
223 CF_CACR_EUSP)
224
Richard Retanubun8706ef32009-01-23 14:07:05 -0500225/* Chip Select 0 : Boot Flash */
226#define CONFIG_SYS_CS0_BASE 0xFFE00000
227#define CONFIG_SYS_CS0_MASK 0x001F0001
228#define CONFIG_SYS_CS0_CTRL 0x00001980
229
230/* Chip Select 1 : External SRAM */
231#define CONFIG_SYS_CS1_BASE 0x30000000
232#define CONFIG_SYS_CS1_MASK 0x00070001
233#define CONFIG_SYS_CS1_CTRL 0x00001900
Marian Balakowicz78b123c2006-05-09 11:54:44 +0200234
TsiChungLiewf28e1bd2007-08-15 20:32:06 -0500235#endif /* _M5271EVB_H */