ppmc7xx.h 11.4 KB
Newer Older
1 2 3
/*
 * ppmc7xx.h
 * ---------
W
Wolfgang Denk 已提交
4
 *
5
 * Wind River PPMC 7xx/74xx board configuration file.
W
Wolfgang Denk 已提交
6
 *
7 8 9 10 11 12 13 14 15 16 17 18
 * By Richard Danter (richard.danter@windriver.com)
 * Copyright (C) 2005 Wind River Systems
 */


#ifndef __CONFIG_H
#define __CONFIG_H

#define CONFIG_PPMC7XX


/*===================================================================
W
Wolfgang Denk 已提交
19
 *
20
 * User configurable settings - Modify to your preference
W
Wolfgang Denk 已提交
21
 *
22 23 24 25 26
 *===================================================================
 */

/*
 * Debug
W
Wolfgang Denk 已提交
27
 *
28 29 30
 * DEBUG		- Define this is you want extra debug info
 * GTREGREAD		- Required to build with debug
 * do_bdinfo		- Required to build with debug
31 32
 */

33 34
#ifdef	DEBUG
#define	GTREGREAD(x)	0xFFFFFFFF
35
#define	do_bdinfo(a,b,c,d)
36
#endif
37 38 39

/*
 * CPU type
W
Wolfgang Denk 已提交
40
 *
41 42 43 44
 * CONFIG_7xx		- We have a 750 or 755 CPU
 * CONFIG_74xx		- We have a 7400 CPU
 * CONFIG_ALTIVEC	- We have altivec enabled CPU (only 7400)
 * CONFIG_BUS_CLK	- System bus clock in Hz
45 46 47 48 49
 */

#define	CONFIG_7xx
#undef	CONFIG_74xx
#undef	CONFIG_ALTIVEC
50
#define CONFIG_BUS_CLK	66000000
51

52
#define	CONFIG_SYS_TEXT_BASE	0xFFF00000
53

54 55 56 57
#ifndef __ASSEMBLY__
#include <galileo/core.h>
#endif

58 59
/*
 * Monitor configuration
W
Wolfgang Denk 已提交
60
 *
61
 * List of command sets to include in shell
W
Wolfgang Denk 已提交
62
 *
63
 * The following command sets have been tested and known to work:
W
Wolfgang Denk 已提交
64
 *
65 66 67 68 69 70 71 72 73
 * CMD_CACHE		- Cache control commands
 * CMD_MEMORY		- Memory display, change and test commands
 * CMD_FLASH		- Erase and program flash
 * CMD_ENV		- Environment commands
 * CMD_RUN		- Run commands stored in env vars
 * CMD_ELF		- Load ELF files
 * CMD_NET		- Networking/file download commands
 * CMD_PIN		- ICMP Echo Request command
 * CMD_PCI		- PCI Bus scanning command
74 75
 */

76 77 78 79 80 81 82 83 84
/*
 * BOOTP options
 */
#define CONFIG_BOOTP_BOOTFILESIZE
#define CONFIG_BOOTP_BOOTPATH
#define CONFIG_BOOTP_GATEWAY
#define CONFIG_BOOTP_HOSTNAME


85 86 87 88 89 90
/*
 * Command line configuration.
 */
#include <config_cmd_default.h>

#define CONFIG_CMD_FLASH
91
#define CONFIG_CMD_SAVEENV
92 93 94 95 96 97 98
#define CONFIG_CMD_RUN
#define CONFIG_CMD_ELF
#define CONFIG_CMD_NET
#define CONFIG_CMD_PING
#define CONFIG_CMD_PCI

#undef CONFIG_CMD_KGDB
99 100 101 102 103 104


/*
 * Serial configuration
 *
 * CONFIG_CONS_INDEX		- Serial console port number (COM1)
105
 * CONFIG_BAUDRATE		- Serial speed
106 107
 */

108 109
#define CONFIG_CONS_INDEX	1
#define CONFIG_BAUDRATE		9600
110 111 112 113


/*
 * PCI config
W
Wolfgang Denk 已提交
114
 *
115 116
 * CONFIG_PCI			- Enable PCI bus
 * CONFIG_PCI_PNP		- Enable Plug & Play support
117 118 119 120
 * CONFIG_PCI_SCAN_SHOW		- Enable display of devices at startup
 */

#define	CONFIG_PCI
121
#define	CONFIG_PCI_INDIRECT_BRIDGE
122 123 124 125 126 127
#define	CONFIG_PCI_PNP
#undef	CONFIG_PCI_SCAN_SHOW


/*
 * Network config
W
Wolfgang Denk 已提交
128
 *
129 130
 * CONFIG_EEPRO100		- Intel 8255x Ethernet Controller
 * CONFIG_EEPRO100_SROM_WRITE	- Enable writing to network card ROM
131 132 133 134 135 136 137 138
 */

#define	CONFIG_EEPRO100
#define	CONFIG_EEPRO100_SROM_WRITE


/*
 * Enable extra init functions
W
Wolfgang Denk 已提交
139
 *
140 141 142 143 144
 * CONFIG_MISC_INIT_F		- Call pre-relocation init functions
 * CONFIG_MISC_INIT_R		- Call post relocation init functions
 */

#undef	CONFIG_MISC_INIT_F
W
Wolfgang Denk 已提交
145
#define CONFIG_MISC_INIT_R
146 147 148 149


/*
 * Boot config
W
Wolfgang Denk 已提交
150
 *
151
 * CONFIG_BOOTCOMMAND		- Command(s) to execute to auto-boot
152
 * CONFIG_BOOTDELAY		- How long to wait before auto-boot (in sec)
153 154 155 156 157 158 159 160 161 162 163
 */

#define CONFIG_BOOTCOMMAND		\
	"bootp;" \
	"setenv bootargs root=/dev/nfs rw nfsroot=$(serverip):$(rootpath) " \
	"ip=$(ipaddr):$(serverip):$(gatewayip):$(netmask):$(hostname)::off;" \
	"bootm"
#define CONFIG_BOOTDELAY		5


/*===================================================================
W
Wolfgang Denk 已提交
164
 *
165
 * Board configuration settings - You should not need to modify these
W
Wolfgang Denk 已提交
166
 *
167 168 169 170 171 172
 *===================================================================
 */


/*
 * Memory map
W
Wolfgang Denk 已提交
173
 *
174
 * This board runs in a standard CHRP (Map-B) configuration.
W
Wolfgang Denk 已提交
175
 *
176
 *	Type	    Start	End	    Size    Width   Chip Sel
177
 *	----------- ----------- ----------- ------- ------- --------
178 179 180 181 182
 *	SDRAM	    0x00000000	0x04000000  64MB    64b	    SDRAMCS0
 *	User LED's  0x78000000				    RCS3
 *	UART	    0x7C000000				    RCS2
 *	Mailbox	    0xFF000000				    RCS1
 *	Flash	    0xFFC00000	0xFFFFFFFF   4MB    64b	    RCS0
W
Wolfgang Denk 已提交
183
 *
184
 * Flash sectors are laid out as follows.
W
Wolfgang Denk 已提交
185
 *
186
 *	Sector	Start		End	Size	Comments
187
 *	------- ----------- ----------- ------- -----------
188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206
 *	 0	0xFFC00000  0xFFC3FFFF	256KB
 *	 1	0xFFC40000  0xFFC7FFFF	256KB
 *	 2	0xFFC80000  0xFFCBFFFF	256KB
 *	 3	0xFFCC0000  0xFFCFFFFF	256KB
 *	 4	0xFFD00000  0xFFD3FFFF	256KB
 *	 5	0xFFD40000  0xFFD7FFFF	256KB
 *	 6	0xFFD80000  0xFFDBFFFF	256KB
 *	 7	0xFFDC0000  0xFFDFFFFF	256KB
 *	 8	0xFFE00000  0xFFE3FFFF	256KB
 *	 9	0xFFE40000  0xFFE7FFFF	256KB
 *	10	0xFFE80000  0xFFEBFFFF	256KB
 *	11	0xFFEC0000  0xFFEFFFFF	256KB
 *	12	0xFFF00000  0xFFF3FFFF	256KB	U-Boot code here
 *	13	0xFFF40000  0xFFF7FFFF	256KB
 *	14	0xFFF80000  0xFFFBFFFF	256KB
 *	15	0xFFFC0000  0xFFFDFFFF	128KB
 *	16	0xFFFE0000  0xFFFE7FFF	 32KB	U-Boot env vars here
 *	17	0xFFFE8000  0xFFFEFFFF	 32KB	U-Boot backup copy of env vars here
 *	18	0xFFFF0000  0xFFFFFFFF	 64KB
207 208 209 210 211
 */


/*
 * SDRAM config - see memory map details above.
W
Wolfgang Denk 已提交
212
 *
213 214
 * CONFIG_SYS_SDRAM_BASE		- Start address of SDRAM, this _must_ be zero!
 * CONFIG_SYS_SDRAM_SIZE		- Total size of contiguous SDRAM bank(s)
215 216
 */

217 218
#define CONFIG_SYS_SDRAM_BASE		0x00000000
#define CONFIG_SYS_SDRAM_SIZE		0x04000000
219 220


W
Wolfgang Denk 已提交
221
/*
222
 * Flash config - see memory map details above.
W
Wolfgang Denk 已提交
223
 *
224 225 226 227 228 229
 * CONFIG_SYS_FLASH_BASE		- Start address of flash memory
 * CONFIG_SYS_FLASH_SIZE		- Total size of contiguous flash mem
 * CONFIG_SYS_FLASH_ERASE_TOUT		- Erase timeout in ms
 * CONFIG_SYS_FLASH_WRITE_TOUT		- Write timeout in ms
 * CONFIG_SYS_MAX_FLASH_BANKS		- Number of banks of flash on board
 * CONFIG_SYS_MAX_FLASH_SECT		- Number of sectors in a bank
230 231
 */

232 233 234 235 236
#define CONFIG_SYS_FLASH_BASE		0xFFC00000
#define CONFIG_SYS_FLASH_SIZE		0x00400000
#define CONFIG_SYS_FLASH_ERASE_TOUT	250000
#define CONFIG_SYS_FLASH_WRITE_TOUT	5000
#define CONFIG_SYS_MAX_FLASH_BANKS	1
237
#define CONFIG_SYS_MAX_FLASH_SECT	128
238 239 240 241


/*
 * Monitor config - see memory map details above
W
Wolfgang Denk 已提交
242
 *
243 244
 * CONFIG_SYS_MONITOR_BASE		- Base address of monitor code
 * CONFIG_SYS_MALLOC_LEN		- Size of malloc pool (128KB)
245 246
 */

247
#define CONFIG_SYS_MONITOR_BASE	CONFIG_SYS_TEXT_BASE
248
#define CONFIG_SYS_MALLOC_LEN		0x20000
249 250 251 252


/*
 * Command shell settings
W
Wolfgang Denk 已提交
253
 *
254 255 256 257 258 259 260 261 262 263
 * CONFIG_SYS_BARGSIZE			- Boot Argument buffer size
 * CONFIG_SYS_BOOTMAPSZ		- Size of app's mapped RAM at boot (Linux=8MB)
 * CONFIG_SYS_CBSIZE			- Console Buffer (input) size
 * CONFIG_SYS_LOAD_ADDR		- Default load address
 * CONFIG_SYS_LONGHELP			- Provide more detailed help
 * CONFIG_SYS_MAXARGS			- Number of args accepted by monitor commands
 * CONFIG_SYS_MEMTEST_START		- Start address of test to run on RAM
 * CONFIG_SYS_MEMTEST_END		- End address of RAM test
 * CONFIG_SYS_PBSIZE			- Print Buffer (output) size
 * CONFIG_SYS_PROMPT			- Prompt string
264 265
 */

266 267 268 269 270 271 272 273 274
#define CONFIG_SYS_BARGSIZE		1024
#define CONFIG_SYS_BOOTMAPSZ		0x800000
#define CONFIG_SYS_CBSIZE		1024
#define CONFIG_SYS_LOAD_ADDR		0x100000
#define CONFIG_SYS_LONGHELP
#define CONFIG_SYS_MAXARGS		16
#define CONFIG_SYS_MEMTEST_START	0x00040000
#define CONFIG_SYS_MEMTEST_END		0x00040100
#define CONFIG_SYS_PBSIZE		1024
275 276 277 278


/*
 * Environment config - see memory map details above
W
Wolfgang Denk 已提交
279
 *
280
 * CONFIG_ENV_IS_IN_FLASH		- The env variables are stored in flash
281 282 283
 * CONFIG_ENV_ADDR			- Address of the sector containing env vars
 * CONFIG_ENV_SIZE			- Ammount of RAM for env vars (used to save RAM, 4KB)
 * CONFIG_ENV_SECT_SIZE		- Size of sector containing env vars (32KB)
284 285
 */

286
#define CONFIG_ENV_IS_IN_FLASH	1
287 288 289 290 291
#define CONFIG_ENV_ADDR		0xFFFE0000
#define CONFIG_ENV_SIZE		0x1000
#define CONFIG_ENV_ADDR_REDUND	0xFFFE8000
#define CONFIG_ENV_SIZE_REDUND	0x1000
#define CONFIG_ENV_SECT_SIZE	0x8000
292 293 294 295 296 297 298 299


/*
 * Initial RAM config
 *
 * Since the main system RAM is initialised very early, we place the INIT_RAM
 * in the main system RAM just above the exception vectors. The contents are
 * copied to top of RAM by the init code.
W
Wolfgang Denk 已提交
300
 *
301
 * CONFIG_SYS_INIT_RAM_ADDR		- Address of Init RAM, above exception vect
302
 * CONFIG_SYS_INIT_RAM_SIZE		- Size of Init RAM
303
 * GENERATED_GBL_DATA_SIZE		- Ammount of RAM to reserve for global data
304
 * CONFIG_SYS_GBL_DATA_OFFSET		- Start of global data, top of stack
305 306
 */

307
#define CONFIG_SYS_INIT_RAM_ADDR	(CONFIG_SYS_SDRAM_BASE + 0x4000)
308
#define CONFIG_SYS_INIT_RAM_SIZE	0x4000
309
#define CONFIG_SYS_GBL_DATA_OFFSET	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
310 311 312 313


/*
 * Initial BAT config
W
Wolfgang Denk 已提交
314
 *
315 316 317 318 319 320
 * BAT0	- System SDRAM
 * BAT1 - LED's and Serial Port
 * BAT2 - PCI Memory
 * BAT3 - PCI I/O including Flash Memory
 */

321 322 323 324
#define CONFIG_SYS_IBAT0L (CONFIG_SYS_SDRAM_BASE | BATL_PP_10 | BATL_MEMCOHERENCE)
#define CONFIG_SYS_IBAT0U (CONFIG_SYS_SDRAM_BASE | BATU_BL_64M | BATU_VS | BATU_VP)
#define CONFIG_SYS_DBAT0L CONFIG_SYS_IBAT0L
#define CONFIG_SYS_DBAT0U CONFIG_SYS_IBAT0U
325

326 327 328 329
#define CONFIG_SYS_IBAT1L (0x70000000 | BATL_PP_RW | BATL_CACHEINHIBIT)
#define CONFIG_SYS_IBAT1U (0x70000000 | BATU_BL_256M | BATU_VS | BATU_VP)
#define CONFIG_SYS_DBAT1L (0x70000000 | BATL_PP_RW | BATL_CACHEINHIBIT | BATL_GUARDEDSTORAGE)
#define CONFIG_SYS_DBAT1U (0x70000000 | BATU_BL_256M | BATU_VS | BATU_VP)
330

331 332 333 334
#define CONFIG_SYS_IBAT2L (0x80000000 | BATL_PP_RW | BATL_CACHEINHIBIT)
#define CONFIG_SYS_IBAT2U (0x80000000 | BATU_BL_256M | BATU_VS | BATU_VP)
#define CONFIG_SYS_DBAT2L (0x80000000 | BATL_PP_RW | BATL_CACHEINHIBIT | BATL_GUARDEDSTORAGE)
#define CONFIG_SYS_DBAT2U (0x80000000 | BATU_BL_256M | BATU_VS | BATU_VP)
335

336 337 338 339
#define CONFIG_SYS_IBAT3L (0xF0000000 | BATL_PP_RW | BATL_CACHEINHIBIT)
#define CONFIG_SYS_IBAT3U (0xF0000000 | BATU_BL_256M | BATU_VS | BATU_VP)
#define CONFIG_SYS_DBAT3L (0xF0000000 | BATL_PP_RW | BATL_CACHEINHIBIT | BATL_GUARDEDSTORAGE)
#define CONFIG_SYS_DBAT3U (0xF0000000 | BATU_BL_256M | BATU_VS | BATU_VP)
340 341 342 343


/*
 * Cache config
W
Wolfgang Denk 已提交
344
 *
345 346
 * CONFIG_SYS_CACHELINE_SIZE		- Size of a cache line (CPU specific)
 * CONFIG_SYS_L2			- L2 cache enabled if defined
347 348
 * L2_INIT			- L2 cache init flags
 * L2_ENABLE			- L2 cache enable flags
349 350
 */

351 352
#define CONFIG_SYS_CACHELINE_SIZE	32
#undef	CONFIG_SYS_L2
353 354
#define L2_INIT			0
#define L2_ENABLE		0
355 356 357 358


/*
 * Clocks config
W
Wolfgang Denk 已提交
359
 *
360
 * CONFIG_SYS_BUS_CLK			- Bus clock frequency in Hz
361
 * CONFIG_SYS_HZ			- Decrementer freq in Hz
362 363
 */

364 365
#define CONFIG_SYS_BUS_CLK		CONFIG_BUS_CLK
#define CONFIG_SYS_HZ			1000
366 367 368 369


/*
 * Serial port config
W
Wolfgang Denk 已提交
370
 *
371 372 373 374 375
 * CONFIG_SYS_NS16550			- Include the NS16550 driver
 * CONFIG_SYS_NS16550_SERIAL		- Include the serial (wrapper) driver
 * CONFIG_SYS_NS16550_CLK		- Frequency of reference clock
 * CONFIG_SYS_NS16550_REG_SIZE		- 64-bit accesses to 8-bit port
 * CONFIG_SYS_NS16550_COM1		- Base address of 1st serial port
376 377
 */

378 379 380 381 382
#define CONFIG_SYS_NS16550
#define CONFIG_SYS_NS16550_SERIAL
#define CONFIG_SYS_NS16550_CLK		3686400
#define CONFIG_SYS_NS16550_REG_SIZE	-8
#define CONFIG_SYS_NS16550_COM1	0x7C000000
383 384 385 386 387 388


/*
 * PCI Config - Address Map B (CHRP)
 */

389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406
#define CONFIG_SYS_PCI_MEMORY_BUS	0x00000000
#define CONFIG_SYS_PCI_MEMORY_PHYS	0x00000000
#define CONFIG_SYS_PCI_MEMORY_SIZE	0x40000000
#define CONFIG_SYS_PCI_MEM_BUS		0x80000000
#define CONFIG_SYS_PCI_MEM_PHYS	0x80000000
#define CONFIG_SYS_PCI_MEM_SIZE	0x7D000000
#define CONFIG_SYS_ISA_MEM_BUS		0x00000000
#define CONFIG_SYS_ISA_MEM_PHYS	0xFD000000
#define CONFIG_SYS_ISA_MEM_SIZE	0x01000000
#define CONFIG_SYS_PCI_IO_BUS		0x00800000
#define CONFIG_SYS_PCI_IO_PHYS		0xFE800000
#define CONFIG_SYS_PCI_IO_SIZE		0x00400000
#define CONFIG_SYS_ISA_IO_BUS		0x00000000
#define CONFIG_SYS_ISA_IO_PHYS		0xFE000000
#define CONFIG_SYS_ISA_IO_SIZE		0x00800000
#define CONFIG_SYS_ISA_IO_BASE_ADDRESS CONFIG_SYS_ISA_IO_PHYS
#define CONFIG_SYS_ISA_IO		CONFIG_SYS_ISA_IO_PHYS
#define CONFIG_SYS_60X_PCI_IO_OFFSET	CONFIG_SYS_ISA_IO_PHYS
407 408 409 410


/*
 * Extra init functions
W
Wolfgang Denk 已提交
411
 *
412
 * CONFIG_SYS_BOARD_ASM_INIT		- Call assembly init code
413 414
 */

415
#define CONFIG_SYS_BOARD_ASM_INIT
416 417

#endif /* __CONFIG_H */