3
* Heiko Schocher, DENX Software Engineering, hs@denx.de.
5
* See file CREDITS for list of people who contributed to this
8
* This program is free software; you can redistribute it and/or
9
* modify it under the terms of the GNU General Public License as
10
* published by the Free Software Foundation; either version 2 of
11
* the License, or (at your option) any later version.
13
* This program is distributed in the hope that it will be useful,
14
* but WITHOUT ANY WARRANTY; without even the implied warranty of
15
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16
* GNU General Public License for more details.
18
* You should have received a copy of the GNU General Public License
19
* along with this program; if not, write to the Free Software
20
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
24
#ifndef __MANROLAND_MPC52XX__COMMON_H
25
#define __MANROLAND_MPC52XX__COMMON_H
28
* High Level Configuration Options
31
#define CONFIG_MPC5xxx 1 /* This is an MPC5xxx CPU */
32
#define CONFIG_MPC5200 1 /* (more precisely an MPC5200 CPU) */
34
#define CONFIG_SYS_MPC5XXX_CLKIN 33000000 /* ... running at 33.000000MHz */
36
#define CONFIG_HIGH_BATS 1 /* High BATs supported */
39
* Serial console configuration
41
#define CONFIG_PSC_CONSOLE 1 /* console is on PSC1 */
42
#define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200,\
45
#if (TEXT_BASE == 0xFFF00000) /* Boot low */
46
# define CONFIG_SYS_LOWBOOT 1
50
* IPB Bus clocking configuration.
52
#define CONFIG_SYS_IPBCLK_EQUALS_XLBCLK /* define for 133MHz speed */
57
#define CONFIG_HARD_I2C 1 /* I2C with hardware support */
58
#define CONFIG_SYS_I2C_MODULE 2 /* Select I2C module #1 or #2 */
60
#define CONFIG_SYS_I2C_SPEED 100000 /* 100 kHz */
61
#define CONFIG_SYS_I2C_SLAVE 0x7F
64
* EEPROM configuration
66
#define CONFIG_SYS_I2C_EEPROM_ADDR 0x58
67
#define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1
68
#define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 4
69
#define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 10
74
#define CONFIG_RTC_PCF8563
75
#define CONFIG_SYS_I2C_RTC_ADDR 0x51
77
/* I2C SYSMON (LM75) */
78
#define CONFIG_DTT_LM81 1 /* ON Semi's LM75 */
79
#define CONFIG_DTT_SENSORS {0} /* Sensor addresses */
80
#define CONFIG_SYS_DTT_MAX_TEMP 70
81
#define CONFIG_SYS_DTT_LOW_TEMP -30
82
#define CONFIG_SYS_DTT_HYSTERESIS 3
87
#define CONFIG_SYS_FLASH_BASE 0xFF800000
89
#define CONFIG_SYS_FLASH_SIZE 0x00800000 /* 8 MByte */
91
#define CONFIG_ENV_ADDR (TEXT_BASE+0x40000) /* second sector */
92
#define CONFIG_SYS_MAX_FLASH_BANKS 1 /* max num of flash banks
94
#define CONFIG_SYS_FLASH_ERASE_TOUT 240000 /* Flash Erase Timeout [ms]*/
95
#define CONFIG_SYS_FLASH_WRITE_TOUT 500 /* Flash Write Timeout [ms]*/
97
#define CONFIG_FLASH_CFI_DRIVER
98
#define CONFIG_SYS_FLASH_CFI
99
#define CONFIG_SYS_FLASH_EMPTY_INFO
100
#define CONFIG_SYS_FLASH_CFI_AMD_RESET
103
* Environment settings
105
#define CONFIG_ENV_IS_IN_FLASH 1
106
#define CONFIG_ENV_SIZE 0x4000
107
#define CONFIG_ENV_OFFSET_REDUND (CONFIG_ENV_OFFSET+CONFIG_ENV_SECT_SIZE)
108
#define CONFIG_ENV_SIZE_REDUND (CONFIG_ENV_SIZE)
113
#define CONFIG_SYS_MBAR 0xF0000000
114
#define CONFIG_SYS_DEFAULT_MBAR 0x80000000
116
#define CONFIG_SYS_GBL_DATA_SIZE 128
117
#define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_END -\
118
CONFIG_SYS_GBL_DATA_SIZE)
119
#define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
121
#define CONFIG_SYS_SDRAM_BASE 0x00000000
122
#define CONFIG_SYS_SRAM_BASE 0x80100000 /* CS 1 */
123
#define CONFIG_SYS_DISPLAY_BASE 0x80600000 /* CS 3 */
125
/* Settings for XLB = 132 MHz */
127
#define SDRAM_MODE 0x018D0000
128
#define SDRAM_EMODE 0x40090000
129
#define SDRAM_CONTROL 0x714f0f00
130
#define SDRAM_CONFIG1 0x73722930
131
#define SDRAM_CONFIG2 0x47770000
132
#define SDRAM_TAPDELAY 0x10000000
134
/* Use ON-Chip SRAM until RAM will be available */
135
#define CONFIG_SYS_INIT_RAM_ADDR MPC5XXX_SRAM
137
/* preserve space for the post_word at end of on-chip SRAM */
138
#define CONFIG_SYS_INIT_RAM_END MPC5XXX_SRAM_POST_SIZE
140
#define CONFIG_SYS_INIT_RAM_END MPC5XXX_SRAM_SIZE
143
#define CONFIG_SYS_MONITOR_BASE TEXT_BASE
144
#if (CONFIG_SYS_MONITOR_BASE < CONFIG_SYS_FLASH_BASE)
145
# define CONFIG_SYS_RAMBOOT 1
148
#define CONFIG_SYS_MONITOR_LEN (192 << 10)
149
#define CONFIG_SYS_MALLOC_LEN (512 << 10)
150
#define CONFIG_SYS_BOOTMAPSZ (8 << 20)
153
* Ethernet configuration
155
#define CONFIG_MPC5xxx_FEC 1
156
#define CONFIG_MPC5xxx_FEC_MII100
157
#define CONFIG_PHY_ADDR 0x00
160
/*use Hardware WDT */
161
#define CONFIG_HW_WATCHDOG
163
#define CONFIG_SYS_HZ 1000 /* decrementer freq: 1 ms ticks */
165
#define CONFIG_SYS_CACHELINE_SIZE 32 /* For MPC5xxx CPUs */
166
#if defined(CONFIG_CMD_KGDB)
167
# define CONFIG_SYS_CACHELINE_SHIFT 5 /* log base 2 of the above value*/
171
* Various low-level settings
173
#if defined(CONFIG_MPC5200)
174
#define CONFIG_SYS_HID0_INIT HID0_ICE | HID0_ICFI
175
#define CONFIG_SYS_HID0_FINAL HID0_ICE
177
#define CONFIG_SYS_HID0_INIT 0
178
#define CONFIG_SYS_HID0_FINAL 0
181
#define CONFIG_SYS_BOOTCS_START CONFIG_SYS_FLASH_BASE
182
#define CONFIG_SYS_BOOTCS_SIZE CONFIG_SYS_FLASH_SIZE
183
#define CONFIG_SYS_CS0_START CONFIG_SYS_FLASH_BASE
184
#define CONFIG_SYS_CS0_SIZE CONFIG_SYS_FLASH_SIZE
186
/* 8Mbit SRAM @0x80100000 */
187
#define CONFIG_SYS_CS1_START CONFIG_SYS_SRAM_BASE
189
#define CONFIG_SYS_CS_BURST 0x00000000
190
#define CONFIG_SYS_CS_DEADCYCLE 0x33333333
192
/*-----------------------------------------------------------------------
193
* IDE/ATA stuff Supports IDE harddisk
194
*-----------------------------------------------------------------------
197
#undef CONFIG_IDE_8xx_PCCARD /* Use IDE with PC Card Adapter */
199
#undef CONFIG_IDE_8xx_DIRECT /* Direct IDE not supported */
200
#undef CONFIG_IDE_LED /* LED for ide not supported */
202
#define CONFIG_SYS_IDE_MAXBUS 1 /* max. 1 IDE bus */
204
#define CONFIG_IDE_PREINIT 1
206
#define CONFIG_SYS_ATA_IDE0_OFFSET 0x0000
208
#define CONFIG_SYS_ATA_BASE_ADDR MPC5XXX_ATA
210
/* Offset for data I/O */
211
#define CONFIG_SYS_ATA_DATA_OFFSET (0x0060)
213
/* Offset for normal register accesses */
214
#define CONFIG_SYS_ATA_REG_OFFSET (CONFIG_SYS_ATA_DATA_OFFSET)
216
/* Offset for alternate registers */
217
#define CONFIG_SYS_ATA_ALT_OFFSET (0x005C)
219
/* Interval between registers */
220
#define CONFIG_SYS_ATA_STRIDE 4
222
#define CONFIG_ATAPI 1
224
#define OF_CPU "PowerPC,5200@0"
225
#define OF_SOC "soc5200@f0000000"
226
#define OF_TBCLK (bd->bi_busfreq / 4)
227
#define OF_STDOUT_PATH "/soc5200@f0000000/serial@2000"
228
#define CONFIG_OF_IDE_FIXUP
230
#endif /* __MANROLAND_MPC52XX__COMMON_H */