stxgp3.h 12.1 KB
Newer Older
W
wdenk 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41
/*
 * (C) Copyright 2003 Embedded Edge, LLC
 * Dan Malek <dan@embeddededge.com>
 * Copied from ADS85xx.
 * Updates for Silicon Tx GP3 8560 board.
 *
 * (C) Copyright 2002,2003 Motorola,Inc.
 * Xianghua Xiao <X.Xiao@motorola.com>
 *
 * See file CREDITS for list of people who contributed to this
 * project.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License as
 * published by the Free Software Foundation; either version 2 of
 * the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 * MA 02111-1307 USA
 */

/* mpc8560ads board configuration file */
/* please refer to doc/README.mpc85xx for more info */
/* make sure you change the MAC address and other network params first,
 * search for CONFIG_ETHADDR,CONFIG_SERVERIP,etc in this file
 */

#ifndef __CONFIG_H
#define __CONFIG_H

/* High Level Configuration Options */
#define CONFIG_BOOKE		1	/* BOOKE		*/
#define CONFIG_E500		1	/* BOOKE e500 family	*/
#define CONFIG_MPC85xx		1	/* MPC8540/MPC8560	*/
42
#define CONFIG_CPM2		1	/* has CPM2 */
W
wdenk 已提交
43
#define CONFIG_STXGP3		1	/* Silicon Tx GPPP board specific*/
44
#define CONFIG_MPC8560		1
W
wdenk 已提交
45

W
Wolfgang Denk 已提交
46 47
#undef  CONFIG_PCI			/* pci ethernet support	*/
#define CONFIG_TSEC_ENET		/* tsec ethernet support*/
W
wdenk 已提交
48 49 50 51 52
#undef  CONFIG_ETHER_ON_FCC             /* cpm FCC ethernet support */
#define CONFIG_ENV_OVERWRITE
#define CONFIG_SPD_EEPROM               /* Use SPD EEPROM for DDR setup */
#undef  CONFIG_DDR_ECC			/* only for ECC DDR module */
#define CONFIG_DDR_DLL                  /* possible DLL fix needed */
W
wdenk 已提交
53 54
#define CONFIG_DDR_2T_TIMING		/* Sets the 2T timing bit */

55
#define CONFIG_FSL_LAW		1	/* Use common FSL init code */
W
wdenk 已提交
56

W
wdenk 已提交
57
/* sysclk for MPC85xx
W
wdenk 已提交
58 59 60 61 62 63 64 65
 */

#define CONFIG_SYS_CLK_FREQ     33333333 /* most pci cards are 33Mhz */

/* Blinkin' LEDs for Robert :-)
*/
#define CONFIG_SHOW_ACTIVITY 1

W
wdenk 已提交
66 67 68
/*
 * These can be toggled for performance analysis, otherwise use default.
 */
W
wdenk 已提交
69
#define CONFIG_L2_CACHE                     /* toggle L2 cache         */
W
wdenk 已提交
70 71
#define  CONFIG_BTB                          /* toggle branch predition */
#define  CONFIG_ADDR_STREAMING               /* toggle addr streaming   */
W
wdenk 已提交
72

W
wdenk 已提交
73
#define CONFIG_BOARD_EARLY_INIT_F   1        /* Call board_pre_init      */
W
wdenk 已提交
74 75 76 77 78 79 80

#undef  CFG_DRAM_TEST                       /* memory test, takes time  */
#define CFG_MEMTEST_START       0x00200000  /* memtest region */
#define CFG_MEMTEST_END         0x00400000


/* Localbus SDRAM is an option, not all boards have it.
W
wdenk 已提交
81 82 83 84 85
 * This address, however, is used to configure a 256M local bus
 * window that includes the Config latch below.
 */
#define CFG_LBC_SDRAM_BASE      0xf0000000      /* Localbus SDRAM */
#define CFG_LBC_SDRAM_SIZE	256		/* LBC SDRAM is 64MB	*/
W
wdenk 已提交
86 87 88 89 90 91 92 93 94 95 96 97

#define CFG_FLASH_BASE        0xff000000      /* start of FLASH 16M    */
#define CFG_BR0_PRELIM        0xff001801      /* port size 32bit      */

#define CFG_OR0_PRELIM          0xff000ff7      /* 16 MB Flash           */
#define CFG_MAX_FLASH_BANKS	1		/* number of banks	*/
#define CFG_MAX_FLASH_SECT	136		/* sectors per device   */
#undef	CFG_FLASH_CHECKSUM
#define CFG_FLASH_ERASE_TOUT	60000	/* Timeout for Flash Erase (in ms)	*/
#define CFG_FLASH_WRITE_TOUT	500	/* Timeout for Flash Write (in ms)	*/

/* The configuration latch is Chip Select 1.
W
wdenk 已提交
98
 * It's an 8-bit latch in the lower 8 bits of the word.
W
wdenk 已提交
99 100 101 102 103
 */
#define CFG_BR1_PRELIM		0xfc001801	/* 32-bit port */
#define CFG_OR1_PRELIM		0xffff0ff7      /* 64K is enough */
#define CFG_LBC_LCLDEVS_BASE	0xfc000000	/* Base of localbus devices */

W
Wolfgang Denk 已提交
104
#define CFG_MONITOR_BASE	TEXT_BASE	/* start of monitor	*/
W
wdenk 已提交
105 106 107 108 109 110 111 112

#if (CFG_MONITOR_BASE < CFG_FLASH_BASE)
#define CFG_RAMBOOT
#else
#undef  CFG_RAMBOOT
#endif

#ifdef CFG_RAMBOOT
W
Wolfgang Denk 已提交
113
#define CFG_CCSRBAR_DEFAULT	0x40000000	/* CCSRBAR by BDI cfg	*/
W
wdenk 已提交
114
#else
W
Wolfgang Denk 已提交
115
#define CFG_CCSRBAR_DEFAULT	0xff700000	/* CCSRBAR Default	*/
W
wdenk 已提交
116 117
#endif
#define CFG_CCSRBAR             0xfdf00000      /* relocated CCSRBAR    */
118
#define CFG_CCSRBAR_PHYS	CFG_CCSRBAR	/* physical addr of CCSRBAR */
W
wdenk 已提交
119 120 121
#define CFG_IMMR		CFG_CCSRBAR	/* PQII uses CFG_IMMR	*/


W
wdenk 已提交
122 123 124
/*
 * DDR Setup
 */
W
wdenk 已提交
125

W
wdenk 已提交
126 127 128 129 130 131 132
/*
 * Base addresses -- Note these are effective addresses where the
 * actual resources get mapped (not physical addresses)
 */
#define CFG_DDR_SDRAM_BASE	0x00000000	/* DDR is system memory  */
#define CFG_SDRAM_BASE		CFG_DDR_SDRAM_BASE

W
Wolfgang Denk 已提交
133
#define SPD_EEPROM_ADDRESS	0x54		/*  DDR DIMM */
W
wdenk 已提交
134 135 136 137 138 139

#undef CONFIG_CLOCKS_IN_MHZ

/* local bus definitions */
#define CFG_BR2_PRELIM		0xf8001861	/* 64MB localbus SDRAM  */
#define CFG_OR2_PRELIM		0xfc006901
W
Wolfgang Denk 已提交
140
#define CFG_LBC_LCRR		0x00030004	/* local bus freq	*/
W
wdenk 已提交
141 142 143 144 145 146 147 148 149 150
#define CFG_LBC_LBCR		0x00000000
#define CFG_LBC_LSRT		0x20000000
#define CFG_LBC_MRTPR		0x20000000
#define CFG_LBC_LSDMR_1		0x2861b723
#define CFG_LBC_LSDMR_2		0x0861b723
#define CFG_LBC_LSDMR_3		0x0861b723
#define CFG_LBC_LSDMR_4		0x1861b723
#define CFG_LBC_LSDMR_5		0x4061b723

#define CONFIG_L1_INIT_RAM
W
Wolfgang Denk 已提交
151
#define CFG_INIT_RAM_LOCK	1
W
wdenk 已提交
152
#define CFG_INIT_RAM_ADDR       0x60000000      /* Initial RAM address  */
W
Wolfgang Denk 已提交
153
#define CFG_INIT_RAM_END	0x4000		/* End of used area in RAM */
W
wdenk 已提交
154

W
Wolfgang Denk 已提交
155
#define CFG_GBL_DATA_SIZE	128		/* num bytes initial data */
W
wdenk 已提交
156 157 158
#define CFG_GBL_DATA_OFFSET	(CFG_INIT_RAM_END - CFG_GBL_DATA_SIZE)
#define CFG_INIT_SP_OFFSET	CFG_GBL_DATA_OFFSET

W
Wolfgang Denk 已提交
159 160
#define CFG_MONITOR_LEN		(256 * 1024)    /* Reserve 256 kB for Mon */
#define CFG_MALLOC_LEN		(128 * 1024)    /* Reserved for malloc */
W
wdenk 已提交
161 162

/* Serial Port */
W
Wolfgang Denk 已提交
163 164 165
#define CONFIG_CONS_ON_SCC		/* define if console on SCC */
#undef  CONFIG_CONS_NONE		/* define if console on something else */
#define CONFIG_CONS_INDEX       2	/* which serial channel for console */
W
wdenk 已提交
166

W
Wolfgang Denk 已提交
167
#define CONFIG_BAUDRATE		38400
W
wdenk 已提交
168 169 170 171 172 173 174 175 176 177

#define CFG_BAUDRATE_TABLE  \
	{300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 115200}

/* Use the HUSH parser */
#define CFG_HUSH_PARSER
#ifdef  CFG_HUSH_PARSER
#define CFG_PROMPT_HUSH_PS2 "> "
#endif

178 179 180 181 182
/*
 * I2C
 */
#define CONFIG_FSL_I2C		/* Use FSL common I2C driver */
#define CONFIG_HARD_I2C		/* I2C with hardware support*/
W
wdenk 已提交
183 184 185 186 187 188 189 190 191
#undef	CONFIG_SOFT_I2C			/* I2C bit-banged */
#define CFG_I2C_SPEED		400000	/* I2C speed and slave address	*/
#define CFG_I2C_SLAVE		0x7F
#if 0
#define CFG_I2C_NOPROBES        {0x00}  /* Don't probe these addrs */
#else
/* I did the 'if 0' so we could keep the syntax above if ever needed. */
#undef CFG_I2C_NOPROBES
#endif
192
#define CFG_I2C_OFFSET		0x3000
W
wdenk 已提交
193

W
wdenk 已提交
194 195 196 197 198 199 200 201 202 203 204 205 206 207
/* RapdIO Map configuration, mapped 1:1.
*/
#define CFG_RIO_MEM_BASE	0xc0000000
#define CFG_RIO_MEM_PHYS	CFG_RIO_MEM_BASE
#define CFG_RIO_MEM_SIZE	0x200000000	/* 512 M */

/* Standard 8560 PCI addressing, mapped 1:1.
*/
#define CFG_PCI1_MEM_BASE	0x80000000
#define CFG_PCI1_MEM_PHYS	CFG_PCI1_MEM_BASE
#define CFG_PCI1_MEM_SIZE	0x20000000	/* 512M */
#define CFG_PCI1_IO_BASE	0xe2000000
#define CFG_PCI1_IO_PHYS	CFG_PCI1_IO_BASE
#define CFG_PCI1_IO_SIZE	0x01000000	/* 16 M */
W
wdenk 已提交
208

W
Wolfgang Denk 已提交
209
#if defined(CONFIG_PCI)			/* PCI Ethernet card */
W
wdenk 已提交
210

W
wdenk 已提交
211
#define CONFIG_NET_MULTI
W
Wolfgang Denk 已提交
212
#define CONFIG_PCI_PNP			/* do pci plug-and-play */
W
wdenk 已提交
213 214 215 216 217

#undef CONFIG_EEPRO100
#undef CONFIG_TULIP

#if !defined(CONFIG_PCI_PNP)
W
Wolfgang Denk 已提交
218
  #define PCI_ENET0_IOADDR	0xe0000000
W
wdenk 已提交
219
  #define PCI_ENET0_MEMADDR     0xe0000000
W
Wolfgang Denk 已提交
220
  #define PCI_IDSEL_NUMBER      0x0c	/* slot0->3(IDSEL)=12->15 */
W
wdenk 已提交
221
#endif
W
wdenk 已提交
222 223 224 225 226 227 228 229 230

#undef CONFIG_PCI_SCAN_SHOW
#define CFG_PCI_SUBSYS_VENDORID 0x1057  /* Motorola */

#endif /* CONFIG_PCI */

#if defined(CONFIG_TSEC_ENET)

#ifndef CONFIG_NET_MULTI
W
Wolfgang Denk 已提交
231
#define CONFIG_NET_MULTI	1
W
wdenk 已提交
232 233
#endif

W
wdenk 已提交
234
#define CONFIG_MII		1	/* MII PHY management		*/
W
wdenk 已提交
235

236 237 238 239
#define CONFIG_TSEC1	1
#define CONFIG_TSEC1_NAME	"TSEC0"
#define CONFIG_TSEC2	1
#define CONFIG_TSEC2_NAME	"TSEC1"
W
wdenk 已提交
240 241 242 243 244

#define TSEC1_PHY_ADDR		2
#define TSEC2_PHY_ADDR		4
#define TSEC1_PHYIDX		0
#define TSEC2_PHYIDX		0
245 246
#define TSEC1_FLAGS		TSEC_GIGABIT
#define TSEC2_FLAGS		TSEC_GIGABIT
247
#define CONFIG_ETHPRIME		"TSEC0"
W
wdenk 已提交
248

W
wdenk 已提交
249
#elif defined(CONFIG_ETHER_ON_FCC)	/* CPM FCC Ethernet */
W
wdenk 已提交
250

W
wdenk 已提交
251 252 253
#define CONFIG_ETHER_ON_FCC2             /* define if ether on FCC   */
#undef  CONFIG_ETHER_NONE               /* define if ether on something else */
#define CONFIG_ETHER_INDEX      2       /* which channel for ether  */
W
wdenk 已提交
254 255

#if (CONFIG_ETHER_INDEX == 2)
W
wdenk 已提交
256 257 258 259 260 261 262 263 264 265 266 267 268 269 270
  /*
   * - Rx-CLK is CLK13
   * - Tx-CLK is CLK14
   * - Select bus for bd/buffers
   * - Full duplex
   */
  #define CFG_CMXFCR_MASK       (CMXFCR_FC2 | CMXFCR_RF2CS_MSK | CMXFCR_TF2CS_MSK)
  #define CFG_CMXFCR_VALUE      (CMXFCR_RF2CS_CLK13 | CMXFCR_TF2CS_CLK14)
  #define CFG_CPMFCR_RAMTYPE    0
#if 0
  #define CFG_FCC_PSMR          (FCC_PSMR_FDE)
#else
  #define CFG_FCC_PSMR          0
#endif
  #define FETH2_RST		0x01
W
wdenk 已提交
271
#elif (CONFIG_ETHER_INDEX == 3)
W
wdenk 已提交
272 273
  /* need more definitions here for FE3 */
  #define FETH3_RST		0x80
W
Wolfgang Denk 已提交
274
#endif	/* CONFIG_ETHER_INDEX */
W
wdenk 已提交
275 276 277

/* MDIO is done through the TSEC0 control.
*/
W
wdenk 已提交
278 279 280 281 282 283 284 285 286 287 288 289 290 291
#define CONFIG_MII			/* MII PHY management */
#undef CONFIG_BITBANGMII		/* bit-bang MII PHY management	*/

#endif

/* Environment */
/* We use the top boot sector flash, so we have some 16K sectors for env
 */
#ifndef CFG_RAMBOOT
  #define CFG_ENV_IS_IN_FLASH	1
  #define CFG_ENV_ADDR		(CFG_MONITOR_BASE + 0x60000)
  #define CFG_ENV_SECT_SIZE	0x4000	/* 16K (one top sector) for env */
  #define CFG_ENV_SIZE		0x2000
#else
W
wdenk 已提交
292 293 294 295
  #define CFG_NO_FLASH		1	/* Flash is not usable now	*/
  #define CFG_ENV_IS_NOWHERE	1	/* Store ENV in memory only	*/
  #define CFG_ENV_ADDR		(CFG_MONITOR_BASE - 0x1000)
  #define CFG_ENV_SIZE		0x2000
W
wdenk 已提交
296 297 298
#endif

#define CONFIG_BOOTARGS "root=/dev/nfs rw ip=any console=ttyS1,38400"
W
wdenk 已提交
299
#define CONFIG_BOOTCOMMAND	"bootm 0xff000000 0xff100000"
W
wdenk 已提交
300 301 302 303 304
#define CONFIG_BOOTDELAY	3	/* -1 disable autoboot */

#define CONFIG_LOADS_ECHO	1	/* echo on for serial download	*/
#define CFG_LOADS_BAUD_CHANGE	1	/* allow baudrate change	*/

305 306 307 308 309 310 311 312 313
/*
 * BOOTP options
 */
#define CONFIG_BOOTP_BOOTFILESIZE
#define CONFIG_BOOTP_BOOTPATH
#define CONFIG_BOOTP_GATEWAY
#define CONFIG_BOOTP_HOSTNAME


314 315 316 317 318 319 320 321
/*
 * Command line configuration.
 */
#include <config_cmd_default.h>

#define CONFIG_CMD_PING
#define CONFIG_CMD_I2C

W
wdenk 已提交
322
#if defined(CFG_RAMBOOT)
323 324
    #undef CONFIG_CMD_ENV
    #undef CONFIG_CMD_LOADS
W
wdenk 已提交
325
#else
326 327 328 329 330
    #define CONFIG_CMD_ELF
#endif

#if defined(CONFIG_PCI)
    #define CONFIG_CMD_PCI
W
wdenk 已提交
331
#endif
332 333 334 335 336

#if defined(CONFIG_TSEC_ENET) || defined(CONFIG_ETHER_ON_FCC)
    #define CONFIG_CMD_MII
#endif

W
wdenk 已提交
337 338 339 340 341 342 343 344

#undef CONFIG_WATCHDOG			/* watchdog disabled		*/

/*
 * Miscellaneous configurable options
 */
#define CFG_LONGHELP			/* undef to save memory		*/
#define CFG_PROMPT	"GPPP=> "	/* Monitor Command Prompt	*/
345
#if defined(CONFIG_CMD_KGDB)
W
wdenk 已提交
346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370
#define CFG_CBSIZE	1024		/* Console I/O Buffer Size	*/
#else
#define CFG_CBSIZE	256		/* Console I/O Buffer Size	*/
#endif
#define CFG_PBSIZE (CFG_CBSIZE+sizeof(CFG_PROMPT)+16) /* Print Buffer Size */
#define CFG_MAXARGS	16		/* max number of command args	*/
#define CFG_BARGSIZE	CFG_CBSIZE	/* Boot Argument Buffer Size	*/
#define CFG_LOAD_ADDR	0x1000000	/* default load address */
#define CFG_HZ		1000		/* decrementer freq: 1 ms ticks */

/*
 * For booting Linux, the board info and command line data
 * have to be in the first 8 MB of memory, since this is
 * the maximum mapped by the Linux kernel during initialization.
 */
#define CFG_BOOTMAPSZ		(8 << 20) /* Initial Memory map for Linux */

/*
 * Internal Definitions
 *
 * Boot Flags
 */
#define BOOTFLAG_COLD	0x01		/* Normal Power-On: Boot from FLASH */
#define BOOTFLAG_WARM	0x02		/* Software reboot		*/

371
#if defined(CONFIG_CMD_KGDB)
W
wdenk 已提交
372 373 374 375 376 377
#define CONFIG_KGDB_BAUDRATE	230400	/* speed to run kgdb serial port */
#define CONFIG_KGDB_SER_INDEX	2	/* which serial port to use */
#endif

/*Note: change below for your network setting!!! */
#if defined(CONFIG_TSEC_ENET) || defined(CONFIG_ETHER_ON_FCC)
378
#define CONFIG_HAS_ETH0
W
Wolfgang Denk 已提交
379
#define CONFIG_ETHADDR		 00:e0:0c:07:9b:8a
W
wdenk 已提交
380
#define CONFIG_HAS_ETH1
W
Wolfgang Denk 已提交
381
#define CONFIG_ETH1ADDR		 00:e0:0c:07:9b:8b
W
wdenk 已提交
382
#define CONFIG_HAS_ETH2
W
Wolfgang Denk 已提交
383
#define CONFIG_ETH2ADDR		 00:e0:0c:07:9b:8c
W
wdenk 已提交
384 385
#endif

W
Wolfgang Denk 已提交
386 387
#define CONFIG_SERVERIP		192.168.85.1
#define CONFIG_IPADDR		192.168.85.60
W
wdenk 已提交
388 389
#define CONFIG_GATEWAYIP	192.168.85.1
#define CONFIG_NETMASK		255.255.255.0
W
Wolfgang Denk 已提交
390 391 392
#define CONFIG_HOSTNAME		STX_GP3
#define CONFIG_ROOTPATH		/gppproot
#define CONFIG_BOOTFILE		uImage
W
wdenk 已提交
393
#define CONFIG_LOADADDR		0x1000000
W
wdenk 已提交
394 395

#endif	/* __CONFIG_H */