blob: 39c90aa2b0e25e7f9cf324d2b8ce907cea5e23f1 [file] [log] [blame]
wdenkb666c8f2003-03-06 00:58:30 +00001/*
2 * (C) Copyright 2001
3 * Stuart Hughes <stuarth@lineo.com>
4 * This file is based on similar values for other boards found in other
5 * U-Boot config files, and some that I found in the mpc8260ads manual.
6 *
7 * Note: my board is a PILOT rev.
8 * Note: the mpc8260ads doesn't come with a proper Ethernet MAC address.
9 *
Wolfgang Denkbd8ec7e2013-10-07 13:07:26 +020010 * SPDX-License-Identifier: GPL-2.0+
wdenkb666c8f2003-03-06 00:58:30 +000011 */
12
13/*
wdenkabda5ca2003-05-31 18:35:21 +000014 * Config header file for a MPC8266ADS Pilot 16M Ram Simm, 8Mbytes Flash Simm
wdenkb666c8f2003-03-06 00:58:30 +000015 */
16
wdenkabda5ca2003-05-31 18:35:21 +000017/* !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
Wolfgang Denkedb65482005-09-24 21:54:50 +020018 !! !!
wdenkabda5ca2003-05-31 18:35:21 +000019 !! This configuration requires JP3 to be in position 1-2 to work !!
Wolfgang Denk0708bc62010-10-07 21:51:12 +020020 !! To make it work for the default, the CONFIG_SYS_TEXT_BASE define in !!
wdenkabda5ca2003-05-31 18:35:21 +000021 !! board/mpc8266ads/config.mk must be changed from 0xfe000000 to !!
22 !! 0xfff00000 !!
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020023 !! The CONFIG_SYS_HRCW_MASTER define below must also be changed to match !!
Wolfgang Denkedb65482005-09-24 21:54:50 +020024 !! !!
wdenk57b2d802003-06-27 21:31:46 +000025 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
wdenkabda5ca2003-05-31 18:35:21 +000026 */
27
wdenkb666c8f2003-03-06 00:58:30 +000028#ifndef __CONFIG_H
29#define __CONFIG_H
30
31/*
32 * High Level Configuration Options
33 * (easy to change)
34 */
35
wdenkda55c6e2004-01-20 23:12:12 +000036#define CONFIG_MPC8260 1 /* This is an MPC8260 CPU */
37#define CONFIG_MPC8266ADS 1 /* ...on motorola ADS board */
Jon Loeligerf5ad3782005-07-23 10:37:35 -050038#define CONFIG_CPM2 1 /* Has a CPM2 */
wdenkb666c8f2003-03-06 00:58:30 +000039
Wolfgang Denk291ba1b2010-10-06 09:05:45 +020040#define CONFIG_SYS_TEXT_BASE 0xfe000000
41
wdenkda55c6e2004-01-20 23:12:12 +000042#define CONFIG_BOARD_EARLY_INIT_F 1 /* Call board_early_init_f */
Peter Tyserd3d9a502009-09-16 22:03:08 -050043#define CONFIG_RESET_PHY_R 1 /* Call reset_phy() */
wdenkb666c8f2003-03-06 00:58:30 +000044
45/* allow serial and ethaddr to be overwritten */
46#define CONFIG_ENV_OVERWRITE
47
48/*
49 * select serial console configuration
50 *
51 * if either CONFIG_CONS_ON_SMC or CONFIG_CONS_ON_SCC is selected, then
52 * CONFIG_CONS_INDEX must be set to the channel number (1-2 for SMC, 1-4
53 * for SCC).
54 *
55 * if CONFIG_CONS_NONE is defined, then the serial console routines must
56 * defined elsewhere (for example, on the cogent platform, there are serial
57 * ports on the motherboard which are used for the serial console - see
58 * cogent/cma101/serial.[ch]).
59 */
60#undef CONFIG_CONS_ON_SMC /* define if console on SMC */
61#define CONFIG_CONS_ON_SCC /* define if console on SCC */
62#undef CONFIG_CONS_NONE /* define if console on something else */
63#define CONFIG_CONS_INDEX 1 /* which serial channel for console */
64
65/*
66 * select ethernet configuration
67 *
68 * if either CONFIG_ETHER_ON_SCC or CONFIG_ETHER_ON_FCC is selected, then
69 * CONFIG_ETHER_INDEX must be set to the channel number (1-4 for SCC, 1-3
70 * for FCC)
71 *
72 * if CONFIG_ETHER_NONE is defined, then either the ethernet routines must be
Jon Loeliger2517d972007-07-09 17:15:49 -050073 * defined elsewhere (as for the console), or CONFIG_CMD_NET must be unset.
wdenkb666c8f2003-03-06 00:58:30 +000074 */
75#undef CONFIG_ETHER_ON_SCC /* define if ether on SCC */
76#define CONFIG_ETHER_ON_FCC /* define if ether on FCC */
77#undef CONFIG_ETHER_NONE /* define if ether on something else */
78#define CONFIG_ETHER_INDEX 2 /* which channel for ether */
wdenkbf2f8c92003-05-22 22:52:13 +000079#define CONFIG_MII /* MII PHY management */
80#define CONFIG_BITBANGMII /* bit-bang MII PHY management */
81/*
82 * Port pins used for bit-banged MII communictions (if applicable).
83 */
84#define MDIO_PORT 2 /* Port C */
Luigi 'Comio' Mantellini25e30722009-10-10 12:42:22 +020085#define MDIO_DECLARE volatile ioport_t *iop = ioport_addr ( \
86 (immap_t *) CONFIG_SYS_IMMR, MDIO_PORT )
87#define MDC_DECLARE MDIO_DECLARE
88
wdenkbf2f8c92003-05-22 22:52:13 +000089#define MDIO_ACTIVE (iop->pdir |= 0x00400000)
90#define MDIO_TRISTATE (iop->pdir &= ~0x00400000)
91#define MDIO_READ ((iop->pdat & 0x00400000) != 0)
92
93#define MDIO(bit) if(bit) iop->pdat |= 0x00400000; \
94 else iop->pdat &= ~0x00400000
95
96#define MDC(bit) if(bit) iop->pdat |= 0x00200000; \
97 else iop->pdat &= ~0x00200000
98
99#define MIIDELAY udelay(1)
wdenkb666c8f2003-03-06 00:58:30 +0000100
101#if (CONFIG_ETHER_INDEX == 2)
102
103/*
104 * - Rx-CLK is CLK13
105 * - Tx-CLK is CLK14
106 * - Select bus for bd/buffers (see 28-13)
107 * - Half duplex
108 */
Mike Frysinger109de972011-10-17 05:38:58 +0000109# define CONFIG_SYS_CMXFCR_MASK2 (CMXFCR_FC2 | CMXFCR_RF2CS_MSK | CMXFCR_TF2CS_MSK)
110# define CONFIG_SYS_CMXFCR_VALUE2 (CMXFCR_RF2CS_CLK13 | CMXFCR_TF2CS_CLK14)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200111# define CONFIG_SYS_CPMFCR_RAMTYPE 0
112# define CONFIG_SYS_FCC_PSMR (FCC_PSMR_FDE | FCC_PSMR_LPB)
wdenkb666c8f2003-03-06 00:58:30 +0000113
114#endif /* CONFIG_ETHER_INDEX */
115
116/* other options */
117#define CONFIG_HARD_I2C 1 /* To enable I2C support */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200118#define CONFIG_SYS_I2C_SPEED 400000 /* I2C speed and slave address */
119#define CONFIG_SYS_I2C_SLAVE 0x7F
120#define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1
wdenkb666c8f2003-03-06 00:58:30 +0000121
wdenkbf2f8c92003-05-22 22:52:13 +0000122/* PCI */
123#define CONFIG_PCI
Gabor Juhosb4458732013-05-30 07:06:12 +0000124#define CONFIG_PCI_INDIRECT_BRIDGE
wdenkbf2f8c92003-05-22 22:52:13 +0000125#define CONFIG_PCI_PNP
126#define CONFIG_PCI_BOOTDELAY 0
127#undef CONFIG_PCI_SCAN_SHOW
128
wdenkb666c8f2003-03-06 00:58:30 +0000129/*-----------------------------------------------------------------------
130 * Definitions for Serial Presence Detect EEPROM address
131 * (to get SDRAM settings)
132 */
Wolfgang Denkedb65482005-09-24 21:54:50 +0200133#define SPD_EEPROM_ADDRESS 0x50
wdenkb666c8f2003-03-06 00:58:30 +0000134
wdenkbf2f8c92003-05-22 22:52:13 +0000135#define CONFIG_8260_CLKIN 66000000 /* in Hz */
wdenkb666c8f2003-03-06 00:58:30 +0000136#define CONFIG_BAUDRATE 115200
137
Jon Loeligerf4056992007-07-04 22:30:28 -0500138/*
139 * Command line configuration.
140 */
Rune Torgersenb427efc2007-10-17 11:56:31 -0500141#include <config_cmd_default.h>
142
143/* Commands we want, that are not part of default set */
144#define CONFIG_CMD_ASKENV /* ask for env variable */
145#define CONFIG_CMD_CACHE /* icache, dcache */
146#define CONFIG_CMD_DHCP /* DHCP Support */
147#define CONFIG_CMD_DIAG /* Diagnostics */
148#define CONFIG_CMD_IMMAP /* IMMR dump support */
149#define CONFIG_CMD_IRQ /* irqinfo */
150#define CONFIG_CMD_MII /* MII support */
151#define CONFIG_CMD_PCI /* pciinfo */
152#define CONFIG_CMD_PING /* ping support */
153#define CONFIG_CMD_PORTIO /* Port I/O */
154#define CONFIG_CMD_REGINFO /* Register dump */
155#define CONFIG_CMD_SAVES /* save S record dump */
156#define CONFIG_CMD_SDRAM /* SDRAM DIMM SPD info printout */
Jon Loeligerf4056992007-07-04 22:30:28 -0500157
Rune Torgersenb427efc2007-10-17 11:56:31 -0500158/* Commands from default set we don't need */
159#undef CONFIG_CMD_FPGA /* FPGA configuration Support */
160#undef CONFIG_CMD_SETGETDCR /* DCR support on 4xx */
wdenkb666c8f2003-03-06 00:58:30 +0000161
wdenkbf2f8c92003-05-22 22:52:13 +0000162/* Define a command string that is automatically executed when no character
163 * is read on the console interface withing "Boot Delay" after reset.
164 */
Wolfgang Denkedb65482005-09-24 21:54:50 +0200165#undef CONFIG_BOOT_ROOT_INITRD /* Use ram disk for the root file system */
166#define CONFIG_BOOT_ROOT_NFS /* Use a NFS mounted root file system */
wdenkbf2f8c92003-05-22 22:52:13 +0000167
wdenkc35ba4e2004-03-14 22:25:36 +0000168#ifdef CONFIG_BOOT_ROOT_INITRD
wdenkbf2f8c92003-05-22 22:52:13 +0000169#define CONFIG_BOOTCOMMAND \
170 "version;" \
171 "echo;" \
172 "bootp;" \
173 "setenv bootargs root=/dev/ram0 rw " \
Wolfgang Denk86eb3b72005-11-20 21:40:11 +0100174 "ip=${ipaddr}:${serverip}:${gatewayip}:${netmask}:${hostname}::off;" \
wdenkbf2f8c92003-05-22 22:52:13 +0000175 "bootm"
176#endif /* CONFIG_BOOT_ROOT_INITRD */
177
wdenkc35ba4e2004-03-14 22:25:36 +0000178#ifdef CONFIG_BOOT_ROOT_NFS
wdenkbf2f8c92003-05-22 22:52:13 +0000179#define CONFIG_BOOTCOMMAND \
180 "version;" \
181 "echo;" \
182 "bootp;" \
Wolfgang Denk86eb3b72005-11-20 21:40:11 +0100183 "setenv bootargs root=/dev/nfs rw nfsroot=${serverip}:${rootpath} " \
184 "ip=${ipaddr}:${serverip}:${gatewayip}:${netmask}:${hostname}::off;" \
wdenkbf2f8c92003-05-22 22:52:13 +0000185 "bootm"
186#endif /* CONFIG_BOOT_ROOT_NFS */
187
Jon Loeligerdf5f5442007-07-09 21:24:19 -0500188/*
189 * BOOTP options
wdenkbf2f8c92003-05-22 22:52:13 +0000190 */
Jon Loeligerdf5f5442007-07-09 21:24:19 -0500191#define CONFIG_BOOTP_SUBNETMASK
192#define CONFIG_BOOTP_GATEWAY
193#define CONFIG_BOOTP_HOSTNAME
194#define CONFIG_BOOTP_BOOTPATH
195#define CONFIG_BOOTP_BOOTFILESIZE
196#define CONFIG_BOOTP_DNS
wdenkbf2f8c92003-05-22 22:52:13 +0000197
wdenkb666c8f2003-03-06 00:58:30 +0000198#define CONFIG_BOOTDELAY 5 /* autoboot after 5 seconds */
wdenkb666c8f2003-03-06 00:58:30 +0000199
Jon Loeligerf4056992007-07-04 22:30:28 -0500200#if defined(CONFIG_CMD_KGDB)
wdenkb666c8f2003-03-06 00:58:30 +0000201#undef CONFIG_KGDB_ON_SMC /* define if kgdb on SMC */
202#define CONFIG_KGDB_ON_SCC /* define if kgdb on SCC */
203#undef CONFIG_KGDB_NONE /* define if kgdb on something else */
204#define CONFIG_KGDB_INDEX 2 /* which serial channel for kgdb */
205#define CONFIG_KGDB_BAUDRATE 115200 /* speed to run kgdb serial port at */
206#endif
207
208#undef CONFIG_WATCHDOG /* disable platform specific watchdog */
209
210/*
211 * Miscellaneous configurable options
212 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200213#define CONFIG_SYS_LONGHELP /* undef to save memory */
Jon Loeligerf4056992007-07-04 22:30:28 -0500214#if defined(CONFIG_CMD_KGDB)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200215#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
wdenkb666c8f2003-03-06 00:58:30 +0000216#else
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200217#define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */
wdenkb666c8f2003-03-06 00:58:30 +0000218#endif
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200219#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) /* Print Buffer Size */
220#define CONFIG_SYS_MAXARGS 16 /* max number of command args */
221#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot Argument Buffer Size */
wdenkb666c8f2003-03-06 00:58:30 +0000222
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200223#define CONFIG_SYS_MEMTEST_START 0x00100000 /* memtest works on */
224#define CONFIG_SYS_MEMTEST_END 0x00f00000 /* 1 ... 15 MB in DRAM */
wdenkb666c8f2003-03-06 00:58:30 +0000225
wdenkbf2f8c92003-05-22 22:52:13 +0000226#undef CONFIG_CLOCKS_IN_MHZ /* clocks passsed to Linux in MHz */
wdenkb666c8f2003-03-06 00:58:30 +0000227 /* for versions < 2.4.5-pre5 */
228
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200229#define CONFIG_SYS_LOAD_ADDR 0x100000 /* default load address */
wdenkb666c8f2003-03-06 00:58:30 +0000230
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200231#define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200, 230400 }
wdenkb666c8f2003-03-06 00:58:30 +0000232
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200233#define CONFIG_SYS_FLASH_BASE 0xFE000000
wdenkbf2f8c92003-05-22 22:52:13 +0000234#define FLASH_BASE 0xFE000000
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200235#define CONFIG_SYS_MAX_FLASH_BANKS 1 /* max num of memory banks */
236#define CONFIG_SYS_MAX_FLASH_SECT 32 /* max num of sects on one chip */
237#define CONFIG_SYS_FLASH_SIZE 8
238#define CONFIG_SYS_FLASH_ERASE_TOUT 8000 /* Timeout for Flash Erase (in ms) */
239#define CONFIG_SYS_FLASH_WRITE_TOUT 5 /* Timeout for Flash Write (in ms) */
wdenkb666c8f2003-03-06 00:58:30 +0000240
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200241#undef CONFIG_SYS_FLASH_CHECKSUM
wdenkb666c8f2003-03-06 00:58:30 +0000242
243/* this is stuff came out of the Motorola docs */
244/* Only change this if you also change the Hardware configuration Word */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200245#define CONFIG_SYS_DEFAULT_IMMR 0x0F010000
wdenkb666c8f2003-03-06 00:58:30 +0000246
wdenkb666c8f2003-03-06 00:58:30 +0000247/* Set IMMR to 0xF0000000 or above to boot Linux */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200248#define CONFIG_SYS_IMMR 0xF0000000
249#define CONFIG_SYS_BCSR 0xF8000000
250#define CONFIG_SYS_PCI_INT 0xF8200000 /* PCI interrupt controller */
wdenkb666c8f2003-03-06 00:58:30 +0000251
252/* Define CONFIG_VERY_BIG_RAM to allow use of SDRAMs larger than 256MBytes
253 */
254/*#define CONFIG_VERY_BIG_RAM 1*/
255
256/* What should be the base address of SDRAM DIMM and how big is
257 * it (in Mbytes)? This will normally auto-configure via the SPD.
258*/
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200259#define CONFIG_SYS_SDRAM_BASE 0x00000000
260#define CONFIG_SYS_SDRAM_SIZE 16
wdenkb666c8f2003-03-06 00:58:30 +0000261
262#define SDRAM_SPD_ADDR 0x50
263
wdenkb666c8f2003-03-06 00:58:30 +0000264/*-----------------------------------------------------------------------
265 * BR2,BR3 - Base Register
266 * Ref: Section 10.3.1 on page 10-14
267 * OR2,OR3 - Option Register
268 * Ref: Section 10.3.2 on page 10-16
269 *-----------------------------------------------------------------------
270 */
271
272/* Bank 2,3 - SDRAM DIMM
273 */
274
275/* The BR2 is configured as follows:
276 *
277 * - Base address of 0x00000000
278 * - 64 bit port size (60x bus only)
279 * - Data errors checking is disabled
280 * - Read and write access
281 * - SDRAM 60x bus
282 * - Access are handled by the memory controller according to MSEL
283 * - Not used for atomic operations
284 * - No data pipelining is done
285 * - Valid
286 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200287#define CONFIG_SYS_BR2_PRELIM ((CONFIG_SYS_SDRAM_BASE & BRx_BA_MSK) |\
wdenkb666c8f2003-03-06 00:58:30 +0000288 BRx_PS_64 |\
289 BRx_MS_SDRAM_P |\
290 BRx_V)
291
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200292#define CONFIG_SYS_BR3_PRELIM ((CONFIG_SYS_SDRAM_BASE & BRx_BA_MSK) |\
wdenkb666c8f2003-03-06 00:58:30 +0000293 BRx_PS_64 |\
294 BRx_MS_SDRAM_P |\
295 BRx_V)
296
297/* With a 64 MB DIMM, the OR2 is configured as follows:
298 *
299 * - 64 MB
300 * - 4 internal banks per device
301 * - Row start address bit is A8 with PSDMR[PBI] = 0
302 * - 12 row address lines
303 * - Back-to-back page mode
304 * - Internal bank interleaving within save device enabled
305 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200306#if (CONFIG_SYS_SDRAM_SIZE == 64)
307#define CONFIG_SYS_OR2_PRELIM (MEG_TO_AM(CONFIG_SYS_SDRAM_SIZE) |\
wdenkb666c8f2003-03-06 00:58:30 +0000308 ORxS_BPD_4 |\
309 ORxS_ROWST_PBI0_A8 |\
310 ORxS_NUMR_12)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200311#elif (CONFIG_SYS_SDRAM_SIZE == 16)
312#define CONFIG_SYS_OR2_PRELIM (0xFF000C80)
wdenkb666c8f2003-03-06 00:58:30 +0000313#else
314#error "INVALID SDRAM CONFIGURATION"
315#endif
316
317/*-----------------------------------------------------------------------
318 * PSDMR - 60x Bus SDRAM Mode Register
319 * Ref: Section 10.3.3 on page 10-21
320 *-----------------------------------------------------------------------
321 */
322
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200323#if (CONFIG_SYS_SDRAM_SIZE == 64)
wdenkb666c8f2003-03-06 00:58:30 +0000324/* With a 64 MB DIMM, the PSDMR is configured as follows:
325 *
326 * - Bank Based Interleaving,
327 * - Refresh Enable,
328 * - Address Multiplexing where A5 is output on A14 pin
329 * (A6 on A15, and so on),
330 * - use address pins A14-A16 as bank select,
331 * - A9 is output on SDA10 during an ACTIVATE command,
332 * - earliest timing for ACTIVATE command after REFRESH command is 7 clocks,
333 * - earliest timing for ACTIVATE or REFRESH command after PRECHARGE command
334 * is 3 clocks,
335 * - earliest timing for READ/WRITE command after ACTIVATE command is
336 * 2 clocks,
337 * - earliest timing for PRECHARGE after last data was read is 1 clock,
338 * - earliest timing for PRECHARGE after last data was written is 1 clock,
339 * - CAS Latency is 2.
340 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200341#define CONFIG_SYS_PSDMR (PSDMR_RFEN |\
wdenkb666c8f2003-03-06 00:58:30 +0000342 PSDMR_SDAM_A14_IS_A5 |\
343 PSDMR_BSMA_A14_A16 |\
344 PSDMR_SDA10_PBI0_A9 |\
345 PSDMR_RFRC_7_CLK |\
346 PSDMR_PRETOACT_3W |\
347 PSDMR_ACTTORW_2W |\
348 PSDMR_LDOTOPRE_1C |\
349 PSDMR_WRC_1C |\
350 PSDMR_CL_2)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200351#elif (CONFIG_SYS_SDRAM_SIZE == 16)
wdenkb666c8f2003-03-06 00:58:30 +0000352/* With a 16 MB DIMM, the PSDMR is configured as follows:
353 *
354 * configuration parameters found in Motorola documentation
355 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200356#define CONFIG_SYS_PSDMR (0x016EB452)
wdenkb666c8f2003-03-06 00:58:30 +0000357#else
358#error "INVALID SDRAM CONFIGURATION"
359#endif
360
wdenkb666c8f2003-03-06 00:58:30 +0000361#define RS232EN_1 0x02000002
362#define RS232EN_2 0x01000001
363#define FETHIEN 0x08000008
364#define FETH_RST 0x04000004
365
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200366#define CONFIG_SYS_INIT_RAM_ADDR CONFIG_SYS_IMMR
Wolfgang Denk1c2e98e2010-10-26 13:32:32 +0200367#define CONFIG_SYS_INIT_RAM_SIZE 0x4000 /* Size of used area in DPRAM */
Wolfgang Denk0191e472010-10-26 14:34:52 +0200368#define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200369#define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
wdenkb666c8f2003-03-06 00:58:30 +0000370
wdenkabda5ca2003-05-31 18:35:21 +0000371/* Use this HRCW for booting from address 0xfe00000 (JP3 in setting 1-2) */
wdenkbf2f8c92003-05-22 22:52:13 +0000372/* 0x0EB2B645 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200373#define CONFIG_SYS_HRCW_MASTER (( HRCW_BPS11 | HRCW_CIP ) |\
wdenkbf2f8c92003-05-22 22:52:13 +0000374 ( HRCW_L2CPC10 | HRCW_DPPC11 | HRCW_ISB010 ) |\
375 ( HRCW_BMS | HRCW_MMR11 | HRCW_LBPC01 | HRCW_APPC10 ) |\
376 ( HRCW_CS10PC01 | HRCW_MODCK_H0101 ) \
wdenkb666c8f2003-03-06 00:58:30 +0000377 )
wdenkbf2f8c92003-05-22 22:52:13 +0000378
wdenkabda5ca2003-05-31 18:35:21 +0000379/* Use this HRCW for booting from address 0xfff0000 (JP3 in setting 2-3) */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200380/* #define CONFIG_SYS_HRCW_MASTER 0x0cb23645 */
wdenkb666c8f2003-03-06 00:58:30 +0000381
wdenk57b2d802003-06-27 21:31:46 +0000382/* This value should actually be situated in the first 256 bytes of the FLASH
wdenkb666c8f2003-03-06 00:58:30 +0000383 which on the standard MPC8266ADS board is at address 0xFF800000
384 The linker script places it at 0xFFF00000 instead.
385
wdenk57b2d802003-06-27 21:31:46 +0000386 It still works, however, as long as the ADS board jumper JP3 is set to
387 position 2-3 so the board is using the BCSR as Hardware Configuration Word
wdenkb666c8f2003-03-06 00:58:30 +0000388
wdenk57b2d802003-06-27 21:31:46 +0000389 If you want to use the one defined here instead, ust copy the first 256 bytes from
390 0xfff00000 to 0xff800000 (for 8MB flash)
wdenkb666c8f2003-03-06 00:58:30 +0000391
392 - Rune
393
wdenkabda5ca2003-05-31 18:35:21 +0000394*/
wdenkb666c8f2003-03-06 00:58:30 +0000395
396/* no slaves */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200397#define CONFIG_SYS_HRCW_SLAVE1 0
398#define CONFIG_SYS_HRCW_SLAVE2 0
399#define CONFIG_SYS_HRCW_SLAVE3 0
400#define CONFIG_SYS_HRCW_SLAVE4 0
401#define CONFIG_SYS_HRCW_SLAVE5 0
402#define CONFIG_SYS_HRCW_SLAVE6 0
403#define CONFIG_SYS_HRCW_SLAVE7 0
wdenkb666c8f2003-03-06 00:58:30 +0000404
Wolfgang Denk0708bc62010-10-07 21:51:12 +0200405#define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE
Peter Tyser3a1362d2010-10-14 23:33:24 -0500406
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200407#if (CONFIG_SYS_MONITOR_BASE < CONFIG_SYS_FLASH_BASE)
408# define CONFIG_SYS_RAMBOOT
wdenkb666c8f2003-03-06 00:58:30 +0000409#endif
410
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200411#define CONFIG_SYS_MONITOR_LEN (256 << 10) /* Reserve 256 kB for Monitor */
412#define CONFIG_SYS_MALLOC_LEN (128 << 10) /* Reserve 128 kB for malloc() */
413#define CONFIG_SYS_BOOTMAPSZ (8 << 20) /* Initial Memory map for Linux */
wdenkb666c8f2003-03-06 00:58:30 +0000414
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200415#ifndef CONFIG_SYS_RAMBOOT
Jean-Christophe PLAGNIOL-VILLARD53db4cd2008-09-10 22:48:04 +0200416# define CONFIG_ENV_IS_IN_FLASH 1
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200417# define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE + 0x40000)
Jean-Christophe PLAGNIOL-VILLARD7e1cda62008-09-10 22:48:06 +0200418# define CONFIG_ENV_SECT_SIZE 0x40000
wdenkb666c8f2003-03-06 00:58:30 +0000419#else
Jean-Christophe PLAGNIOL-VILLARDfdb79c32008-09-10 22:47:59 +0200420# define CONFIG_ENV_IS_IN_NVRAM 1
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200421# define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - 0x1000)
Jean-Christophe PLAGNIOL-VILLARD7e1cda62008-09-10 22:48:06 +0200422# define CONFIG_ENV_SIZE 0x200
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200423#endif /* CONFIG_SYS_RAMBOOT */
wdenkb666c8f2003-03-06 00:58:30 +0000424
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200425#define CONFIG_SYS_CACHELINE_SIZE 32 /* For MPC8260 CPU */
Jon Loeligerf4056992007-07-04 22:30:28 -0500426#if defined(CONFIG_CMD_KGDB)
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200427# define CONFIG_SYS_CACHELINE_SHIFT 5 /* log base 2 of the above value */
wdenkb666c8f2003-03-06 00:58:30 +0000428#endif
429
wdenkabda5ca2003-05-31 18:35:21 +0000430/*-----------------------------------------------------------------------
Wolfgang Denkedb65482005-09-24 21:54:50 +0200431 * HIDx - Hardware Implementation-dependent Registers 2-11
wdenkabda5ca2003-05-31 18:35:21 +0000432 *-----------------------------------------------------------------------
433 * HID0 also contains cache control - initially enable both caches and
434 * invalidate contents, then the final state leaves only the instruction
435 * cache enabled. Note that Power-On and Hard reset invalidate the caches,
436 * but Soft reset does not.
437 *
438 * HID1 has only read-only information - nothing to set.
439 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200440/*#define CONFIG_SYS_HID0_INIT 0 */
441#define CONFIG_SYS_HID0_INIT (HID0_ICE |\
wdenkabda5ca2003-05-31 18:35:21 +0000442 HID0_DCE |\
443 HID0_ICFI |\
444 HID0_DCI |\
445 HID0_IFEM |\
446 HID0_ABE)
447
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200448#define CONFIG_SYS_HID0_FINAL (HID0_ICE | HID0_IFEM | HID0_ABE )
wdenkb666c8f2003-03-06 00:58:30 +0000449
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200450#define CONFIG_SYS_HID2 0
wdenkb666c8f2003-03-06 00:58:30 +0000451
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200452#define CONFIG_SYS_SYPCR 0xFFFFFFC3
453#define CONFIG_SYS_BCR 0x004C0000
454#define CONFIG_SYS_SIUMCR 0x4E64C000
455#define CONFIG_SYS_SCCR 0x00000000
wdenkb666c8f2003-03-06 00:58:30 +0000456
wdenkbf2f8c92003-05-22 22:52:13 +0000457/* local bus memory map
458 *
459 * 0x00000000-0x03FFFFFF 64MB SDRAM
460 * 0x80000000-0x9FFFFFFF 512MB outbound prefetchable PCI memory window
461 * 0xA0000000-0xBFFFFFFF 512MB outbound non-prefetchable PCI memory window
462 * 0xF0000000-0xF001FFFF 128KB MPC8266 internal memory
Wolfgang Denkedb65482005-09-24 21:54:50 +0200463 * 0xF4000000-0xF7FFFFFF 64MB outbound PCI I/O window
wdenkbf2f8c92003-05-22 22:52:13 +0000464 * 0xF8000000-0xF8007FFF 32KB BCSR
465 * 0xF8100000-0xF8107FFF 32KB ATM UNI
466 * 0xF8200000-0xF8207FFF 32KB PCI interrupt controller
467 * 0xF8300000-0xF8307FFF 32KB EEPROM
468 * 0xFE000000-0xFFFFFFFF 32MB flash
469 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200470#define CONFIG_SYS_BR0_PRELIM 0xFE001801 /* flash */
471#define CONFIG_SYS_OR0_PRELIM 0xFE000836
472#define CONFIG_SYS_BR1_PRELIM (CONFIG_SYS_BCSR | 0x1801) /* BCSR */
473#define CONFIG_SYS_OR1_PRELIM 0xFFFF8010
474#define CONFIG_SYS_BR4_PRELIM 0xF8300801 /* EEPROM */
475#define CONFIG_SYS_OR4_PRELIM 0xFFFF8846
476#define CONFIG_SYS_BR5_PRELIM 0xF8100801 /* PM5350 ATM UNI */
477#define CONFIG_SYS_OR5_PRELIM 0xFFFF8E36
478#define CONFIG_SYS_BR8_PRELIM (CONFIG_SYS_PCI_INT | 0x1801) /* PCI interrupt controller */
479#define CONFIG_SYS_OR8_PRELIM 0xFFFF8010
wdenkbf2f8c92003-05-22 22:52:13 +0000480
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200481#define CONFIG_SYS_RMR 0x0001
482#define CONFIG_SYS_TMCNTSC (TMCNTSC_SEC|TMCNTSC_ALR|TMCNTSC_TCF|TMCNTSC_TCE)
483#define CONFIG_SYS_PISCR (PISCR_PS|PISCR_PTF|PISCR_PTE)
484#define CONFIG_SYS_RCCR 0
485#define CONFIG_SYS_MPTPR 0x00001900
486#define CONFIG_SYS_PSRT 0x00000021
wdenkb666c8f2003-03-06 00:58:30 +0000487
wdenk5256def2003-09-18 10:45:21 +0000488/* This address must not exist */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200489#define CONFIG_SYS_RESET_ADDRESS 0xFCFFFF00
wdenkb666c8f2003-03-06 00:58:30 +0000490
wdenkbf2f8c92003-05-22 22:52:13 +0000491/* PCI Memory map (if different from default map */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200492#define CONFIG_SYS_PCI_SLV_MEM_LOCAL CONFIG_SYS_SDRAM_BASE /* Local base */
493#define CONFIG_SYS_PCI_SLV_MEM_BUS 0x00000000 /* PCI base */
494#define CONFIG_SYS_PICMR0_MASK_ATTRIB (PICMR_MASK_512MB | PICMR_ENABLE | \
wdenk57b2d802003-06-27 21:31:46 +0000495 PICMR_PREFETCH_EN)
wdenkbf2f8c92003-05-22 22:52:13 +0000496
wdenk57b2d802003-06-27 21:31:46 +0000497/*
wdenkbf2f8c92003-05-22 22:52:13 +0000498 * These are the windows that allow the CPU to access PCI address space.
wdenk57b2d802003-06-27 21:31:46 +0000499 * All three PCI master windows, which allow the CPU to access PCI
500 * prefetch, non prefetch, and IO space (see below), must all fit within
wdenkbf2f8c92003-05-22 22:52:13 +0000501 * these windows.
502 */
503
504/* PCIBR0 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200505#define CONFIG_SYS_PCI_MSTR0_LOCAL 0x80000000 /* Local base */
506#define CONFIG_SYS_PCIMSK0_MASK PCIMSK_1GB /* Size of window */
wdenkbf2f8c92003-05-22 22:52:13 +0000507/* PCIBR1 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200508#define CONFIG_SYS_PCI_MSTR1_LOCAL 0xF4000000 /* Local base */
509#define CONFIG_SYS_PCIMSK1_MASK PCIMSK_64MB /* Size of window */
wdenkbf2f8c92003-05-22 22:52:13 +0000510
wdenk57b2d802003-06-27 21:31:46 +0000511/*
wdenkbf2f8c92003-05-22 22:52:13 +0000512 * Master window that allows the CPU to access PCI Memory (prefetch).
513 * This window will be setup with the first set of Outbound ATU registers
514 * in the bridge.
515 */
516
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200517#define CONFIG_SYS_PCI_MSTR_MEM_LOCAL 0x80000000 /* Local base */
518#define CONFIG_SYS_PCI_MSTR_MEM_BUS 0x80000000 /* PCI base */
519#define CONFIG_SYS_CPU_PCI_MEM_START PCI_MSTR_MEM_LOCAL
520#define CONFIG_SYS_PCI_MSTR_MEM_SIZE 0x20000000 /* 512MB */
521#define CONFIG_SYS_POCMR0_MASK_ATTRIB (POCMR_MASK_512MB | POCMR_ENABLE | POCMR_PREFETCH_EN)
wdenkbf2f8c92003-05-22 22:52:13 +0000522
wdenk57b2d802003-06-27 21:31:46 +0000523/*
wdenkbf2f8c92003-05-22 22:52:13 +0000524 * Master window that allows the CPU to access PCI Memory (non-prefetch).
525 * This window will be setup with the second set of Outbound ATU registers
526 * in the bridge.
527 */
528
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200529#define CONFIG_SYS_PCI_MSTR_MEMIO_LOCAL 0xA0000000 /* Local base */
530#define CONFIG_SYS_PCI_MSTR_MEMIO_BUS 0xA0000000 /* PCI base */
531#define CONFIG_SYS_CPU_PCI_MEMIO_START PCI_MSTR_MEMIO_LOCAL
532#define CONFIG_SYS_PCI_MSTR_MEMIO_SIZE 0x20000000 /* 512MB */
533#define CONFIG_SYS_POCMR1_MASK_ATTRIB (POCMR_MASK_512MB | POCMR_ENABLE)
wdenkbf2f8c92003-05-22 22:52:13 +0000534
wdenk57b2d802003-06-27 21:31:46 +0000535/*
wdenkbf2f8c92003-05-22 22:52:13 +0000536 * Master window that allows the CPU to access PCI IO space.
537 * This window will be setup with the third set of Outbound ATU registers
538 * in the bridge.
539 */
540
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200541#define CONFIG_SYS_PCI_MSTR_IO_LOCAL 0xF4000000 /* Local base */
542#define CONFIG_SYS_PCI_MSTR_IO_BUS 0xF4000000 /* PCI base */
543#define CONFIG_SYS_CPU_PCI_IO_START PCI_MSTR_IO_LOCAL
544#define CONFIG_SYS_PCI_MSTR_IO_SIZE 0x04000000 /* 64MB */
545#define CONFIG_SYS_POCMR2_MASK_ATTRIB (POCMR_MASK_64MB | POCMR_ENABLE | POCMR_PCI_IO)
wdenkbf2f8c92003-05-22 22:52:13 +0000546
Wolfgang Denk47f57792005-08-08 01:03:24 +0200547/*
548 * JFFS2 partitions
549 *
550 */
551/* No command line, one static partition, whole device */
Stefan Roeseb1423dd2009-03-19 13:30:36 +0100552#undef CONFIG_CMD_MTDPARTS
Wolfgang Denk47f57792005-08-08 01:03:24 +0200553#define CONFIG_JFFS2_DEV "nor0"
554#define CONFIG_JFFS2_PART_SIZE 0xFFFFFFFF
555#define CONFIG_JFFS2_PART_OFFSET 0x00000000
556
557/* mtdparts command line support */
558/*
Stefan Roeseb1423dd2009-03-19 13:30:36 +0100559#define CONFIG_CMD_MTDPARTS
Wolfgang Denk47f57792005-08-08 01:03:24 +0200560#define MTDIDS_DEFAULT ""
561#define MTDPARTS_DEFAULT ""
562*/
wdenkbf2f8c92003-05-22 22:52:13 +0000563
wdenkb666c8f2003-03-06 00:58:30 +0000564#endif /* __CONFIG_H */