blob: 4d88657ca61ba3778f126c17a69d648473a6d44f [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Heiko Schocher9acb6262006-04-20 08:42:42 +02002/*
Jens Scharsigeb0b43f2012-05-02 00:57:08 +00003 * Configuation settings for the BuS EB+CPU5283 boards (aka EB+MCF-EV123)
Heiko Schocher9acb6262006-04-20 08:42:42 +02004 *
Jens Scharsig35cf3b52009-07-24 10:31:48 +02005 * (C) Copyright 2005-2009 BuS Elektronik GmbH & Co.KG <esw@bus-elektonik.de>
Heiko Schocher9acb6262006-04-20 08:42:42 +02006 */
7
Jens Scharsigeb0b43f2012-05-02 00:57:08 +00008#ifndef _CONFIG_EB_CPU5282_H_
9#define _CONFIG_EB_CPU5282_H_
Heiko Schocher9acb6262006-04-20 08:42:42 +020010
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020011#undef CONFIG_SYS_HALT_BEFOR_RAM_JUMP
Wolfgang Denkb1d71352006-06-10 22:00:40 +020012
Jens Scharsig35cf3b52009-07-24 10:31:48 +020013/*----------------------------------------------------------------------*
14 * High Level Configuration Options (easy to change) *
15 *----------------------------------------------------------------------*/
Heiko Schocher9acb6262006-04-20 08:42:42 +020016
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020017#define CONFIG_SYS_UART_PORT (0)
Heiko Schocher9acb6262006-04-20 08:42:42 +020018
Jens Scharsig35cf3b52009-07-24 10:31:48 +020019#undef CONFIG_MONITOR_IS_IN_RAM /* starts uboot direct */
Heiko Schocher9acb6262006-04-20 08:42:42 +020020
Jens Scharsig35cf3b52009-07-24 10:31:48 +020021/*----------------------------------------------------------------------*
22 * Options *
23 *----------------------------------------------------------------------*/
24
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000025#define STATUS_LED_ACTIVE 0
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000026
Jens Scharsig35cf3b52009-07-24 10:31:48 +020027/*----------------------------------------------------------------------*
28 * Configuration for environment *
29 * Environment is in the second sector of the first 256k of flash *
30 *----------------------------------------------------------------------*/
31
TsiChung Liew0e0c4352008-07-09 15:21:44 -050032#define CONFIG_MCFTMR
33
Jens Scharsig35cf3b52009-07-24 10:31:48 +020034#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
Jens Scharsig35cf3b52009-07-24 10:31:48 +020035#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
Heiko Schocher9acb6262006-04-20 08:42:42 +020036
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020037/*#define CONFIG_SYS_DRAM_TEST 1 */
38#undef CONFIG_SYS_DRAM_TEST
Heiko Schocher9acb6262006-04-20 08:42:42 +020039
Jens Scharsig35cf3b52009-07-24 10:31:48 +020040/*----------------------------------------------------------------------*
41 * Clock and PLL Configuration *
42 *----------------------------------------------------------------------*/
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000043#define CONFIG_SYS_CLK 80000000 /* 8MHz * 8 */
Heiko Schocher9acb6262006-04-20 08:42:42 +020044
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000045/* PLL Configuration: Ext Clock * 8 (see table 9-4 of MCF user manual) */
Heiko Schocher9acb6262006-04-20 08:42:42 +020046
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000047#define CONFIG_SYS_MFD 0x02 /* PLL Multiplication Factor Devider */
Jens Scharsig35cf3b52009-07-24 10:31:48 +020048#define CONFIG_SYS_RFD 0x00 /* PLL Reduce Frecuency Devider */
Heiko Schocher9acb6262006-04-20 08:42:42 +020049
Jens Scharsig35cf3b52009-07-24 10:31:48 +020050/*----------------------------------------------------------------------*
51 * Network *
52 *----------------------------------------------------------------------*/
53
Angelo Durgehelloff56f2b2019-11-15 23:54:15 +010054#ifdef CONFIG_MCFFEC
Jens Scharsig35cf3b52009-07-24 10:31:48 +020055#define CONFIG_SYS_DISCOVER_PHY
Jens Scharsig35cf3b52009-07-24 10:31:48 +020056#define CONFIG_OVERWRITE_ETHADDR_ONCE
Angelo Durgehelloff56f2b2019-11-15 23:54:15 +010057#endif
Jens Scharsig35cf3b52009-07-24 10:31:48 +020058
59/*-------------------------------------------------------------------------
Heiko Schocher9acb6262006-04-20 08:42:42 +020060 * Low Level Configuration Settings
61 * (address mappings, register initial values, etc.)
62 * You should know what you are doing if you make changes here.
Jens Scharsig35cf3b52009-07-24 10:31:48 +020063 *-----------------------------------------------------------------------*/
64
65#define CONFIG_SYS_MBAR 0x40000000
Heiko Schocher9acb6262006-04-20 08:42:42 +020066
Heiko Schocher9acb6262006-04-20 08:42:42 +020067/*-----------------------------------------------------------------------
68 * Definitions for initial stack pointer and data area (in DPRAM)
Jens Scharsig35cf3b52009-07-24 10:31:48 +020069 *-----------------------------------------------------------------------*/
70
71#define CONFIG_SYS_INIT_RAM_ADDR 0x20000000
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000072#define CONFIG_SYS_INIT_RAM_SIZE 0x10000
Jens Scharsig35cf3b52009-07-24 10:31:48 +020073#define CONFIG_SYS_GBL_DATA_OFFSET \
Wolfgang Denk25ddd1f2010-10-26 14:34:52 +020074 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020075#define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
Heiko Schocher9acb6262006-04-20 08:42:42 +020076
77/*-----------------------------------------------------------------------
78 * Start addresses for the final memory configuration
79 * (Set up by the startup code)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020080 * Please note that CONFIG_SYS_SDRAM_BASE _must_ start at 0
Heiko Schocher9acb6262006-04-20 08:42:42 +020081 */
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000082#define CONFIG_SYS_SDRAM_BASE0 0x00000000
83#define CONFIG_SYS_SDRAM_SIZE0 16 /* SDRAM size in MB */
Heiko Schocher9acb6262006-04-20 08:42:42 +020084
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +000085#define CONFIG_SYS_SDRAM_BASE CONFIG_SYS_SDRAM_BASE0
86#define CONFIG_SYS_SDRAM_SIZE CONFIG_SYS_SDRAM_SIZE0
Heiko Schocher9acb6262006-04-20 08:42:42 +020087
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020088#define CONFIG_SYS_MONITOR_LEN 0x20000
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020089#define CONFIG_SYS_BOOTPARAMS_LEN 64*1024
Heiko Schocher9acb6262006-04-20 08:42:42 +020090
91/*
92 * For booting Linux, the board info and command line data
93 * have to be in the first 8 MB of memory, since this is
94 * the maximum mapped by the Linux kernel during initialization ??
95 */
Jens Scharsig35cf3b52009-07-24 10:31:48 +020096#define CONFIG_SYS_BOOTMAPSZ (8 << 20) /* Initial Memory map for Linux */
Heiko Schocher9acb6262006-04-20 08:42:42 +020097
98/*-----------------------------------------------------------------------
99 * FLASH organization
100 */
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000101#define CONFIG_FLASH_SHOW_PROGRESS 45
Jens Scharsig35cf3b52009-07-24 10:31:48 +0200102
103#define CONFIG_SYS_FLASH_BASE CONFIG_SYS_CS0_BASE
104#define CONFIG_SYS_INT_FLASH_BASE 0xF0000000
105#define CONFIG_SYS_INT_FLASH_ENABLE 0x21
106
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000107#define CONFIG_SYS_MAX_FLASH_SECT 128
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200108#define CONFIG_SYS_FLASH_ERASE_TOUT 10000000
Heiko Schocher9acb6262006-04-20 08:42:42 +0200109
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000110#define CONFIG_SYS_FLASH_SIZE 16*1024*1024
111#define CONFIG_SYS_FLASH_CFI_WIDTH FLASH_CFI_16BIT
112
113#define CONFIG_SYS_FLASH_BANKS_LIST { CONFIG_SYS_FLASH_BASE }
114
Heiko Schocher9acb6262006-04-20 08:42:42 +0200115/*-----------------------------------------------------------------------
116 * Cache Configuration
117 */
Heiko Schocher9acb6262006-04-20 08:42:42 +0200118
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600119#define ICACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \
Wolfgang Denk553f0982010-10-26 13:32:32 +0200120 CONFIG_SYS_INIT_RAM_SIZE - 8)
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600121#define DCACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \
Wolfgang Denk553f0982010-10-26 13:32:32 +0200122 CONFIG_SYS_INIT_RAM_SIZE - 4)
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600123#define CONFIG_SYS_ICACHE_INV (CF_CACR_CINV + CF_CACR_DCM)
124#define CONFIG_SYS_CACHE_ACR0 (CONFIG_SYS_SDRAM_BASE | \
125 CF_ADDRMASK(CONFIG_SYS_SDRAM_SIZE) | \
126 CF_ACR_EN | CF_ACR_SM_ALL)
127#define CONFIG_SYS_CACHE_ICACR (CF_CACR_CENB | CF_CACR_DISD | \
128 CF_CACR_CEIB | CF_CACR_DBWE | \
129 CF_CACR_EUSP)
130
Heiko Schocher9acb6262006-04-20 08:42:42 +0200131/*-----------------------------------------------------------------------
132 * Memory bank definitions
133 */
134
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000135#define CONFIG_SYS_CS0_BASE 0xFF000000
TsiChung Liew012522f2008-10-21 10:03:07 +0000136#define CONFIG_SYS_CS0_CTRL 0x00001980
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000137#define CONFIG_SYS_CS0_MASK 0x00FF0001
Heiko Schocher9acb6262006-04-20 08:42:42 +0200138
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000139#define CONFIG_SYS_CS2_BASE 0xE0000000
140#define CONFIG_SYS_CS2_CTRL 0x00001980
141#define CONFIG_SYS_CS2_MASK 0x000F0001
142
143#define CONFIG_SYS_CS3_BASE 0xE0100000
144#define CONFIG_SYS_CS3_CTRL 0x00001980
TsiChung Liew012522f2008-10-21 10:03:07 +0000145#define CONFIG_SYS_CS3_MASK 0x000F0001
Heiko Schocher9acb6262006-04-20 08:42:42 +0200146
147/*-----------------------------------------------------------------------
148 * Port configuration
149 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200150#define CONFIG_SYS_PACNT 0x0000000 /* Port A D[31:24] */
151#define CONFIG_SYS_PADDR 0x0000000
152#define CONFIG_SYS_PADAT 0x0000000
Heiko Schocher9acb6262006-04-20 08:42:42 +0200153
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200154#define CONFIG_SYS_PBCNT 0x0000000 /* Port B D[23:16] */
155#define CONFIG_SYS_PBDDR 0x0000000
156#define CONFIG_SYS_PBDAT 0x0000000
Heiko Schocher9acb6262006-04-20 08:42:42 +0200157
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200158#define CONFIG_SYS_PCCNT 0x0000000 /* Port C D[15:08] */
159#define CONFIG_SYS_PCDDR 0x0000000
160#define CONFIG_SYS_PCDAT 0x0000000
Heiko Schocher9acb6262006-04-20 08:42:42 +0200161
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200162#define CONFIG_SYS_PDCNT 0x0000000 /* Port D D[07:00] */
163#define CONFIG_SYS_PCDDR 0x0000000
164#define CONFIG_SYS_PCDAT 0x0000000
Heiko Schocher9acb6262006-04-20 08:42:42 +0200165
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000166#define CONFIG_SYS_PASPAR 0x0F0F
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200167#define CONFIG_SYS_PEHLPAR 0xC0
Jens Scharsig35cf3b52009-07-24 10:31:48 +0200168#define CONFIG_SYS_PUAPAR 0x0F
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200169#define CONFIG_SYS_DDRUA 0x05
170#define CONFIG_SYS_PJPAR 0xFF
Heiko Schocher9acb6262006-04-20 08:42:42 +0200171
172/*-----------------------------------------------------------------------
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000173 * I2C
174 */
175
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000176#ifdef CONFIG_CMD_DATE
177#define CONFIG_RTC_DS1338
178#define CONFIG_I2C_RTC_ADDR 0x68
179#endif
180
181/*-----------------------------------------------------------------------
Jens Scharsig35cf3b52009-07-24 10:31:48 +0200182 * VIDEO configuration
Heiko Schocher9acb6262006-04-20 08:42:42 +0200183 */
184
Jens Scharsig35cf3b52009-07-24 10:31:48 +0200185#define CONFIG_SYS_VCXK_DEFAULT_LINEALIGN 2
186#define CONFIG_SYS_VCXK_DOUBLEBUFFERED 1
Jens Scharsig (BuS Elektronik)d858c332012-10-30 00:46:05 +0000187#define CONFIG_SYS_VCXK_BASE CONFIG_SYS_CS2_BASE
Jens Scharsig35cf3b52009-07-24 10:31:48 +0200188
189#define CONFIG_SYS_VCXK_ACKNOWLEDGE_PORT MCFGPTB_GPTPORT
190#define CONFIG_SYS_VCXK_ACKNOWLEDGE_DDR MCFGPTB_GPTDDR
191#define CONFIG_SYS_VCXK_ACKNOWLEDGE_PIN 0x0001
192
193#define CONFIG_SYS_VCXK_ENABLE_PORT MCFGPTB_GPTPORT
194#define CONFIG_SYS_VCXK_ENABLE_DDR MCFGPTB_GPTDDR
195#define CONFIG_SYS_VCXK_ENABLE_PIN 0x0002
196
197#define CONFIG_SYS_VCXK_REQUEST_PORT MCFGPTB_GPTPORT
198#define CONFIG_SYS_VCXK_REQUEST_DDR MCFGPTB_GPTDDR
199#define CONFIG_SYS_VCXK_REQUEST_PIN 0x0004
200
201#define CONFIG_SYS_VCXK_INVERT_PORT MCFGPIO_PORTE
202#define CONFIG_SYS_VCXK_INVERT_DDR MCFGPIO_DDRE
203#define CONFIG_SYS_VCXK_INVERT_PIN MCFGPIO_PORT2
204
Heiko Schocher9acb6262006-04-20 08:42:42 +0200205#endif /* _CONFIG_M5282EVB_H */
206/*---------------------------------------------------------------------*/