blob: 94d73295de85e9b0a7898f729ff01394ff27c0f7 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Dave Liu24c3aca2006-12-07 21:13:15 +08002/*
3 * Copyright (C) 2006 Freescale Semiconductor, Inc.
Dave Liu24c3aca2006-12-07 21:13:15 +08004 */
5
6#ifndef __CONFIG_H
7#define __CONFIG_H
8
Dave Liu24c3aca2006-12-07 21:13:15 +08009/*
10 * High Level Configuration Options
11 */
12#define CONFIG_E300 1 /* E300 family */
Wolfgang Denk2ae18242010-10-06 09:05:45 +020013
Dave Liu24c3aca2006-12-07 21:13:15 +080014/*
Dave Liu24c3aca2006-12-07 21:13:15 +080015 * System IO Config
16 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020017#define CONFIG_SYS_SICRL 0x00000000
Dave Liu24c3aca2006-12-07 21:13:15 +080018
Dave Liu24c3aca2006-12-07 21:13:15 +080019/*
Dave Liu24c3aca2006-12-07 21:13:15 +080020 * DDR Setup
21 */
Mario Six8a81bfd2019-01-21 09:18:15 +010022#define CONFIG_SYS_SDRAM_BASE 0x00000000 /* DDR is system memory */
Joe Hershberger989091a2011-10-11 23:57:13 -050023#define CONFIG_SYS_DDRCDR 0x73000002 /* DDR II voltage is 1.8V */
Dave Liu24c3aca2006-12-07 21:13:15 +080024
25#undef CONFIG_SPD_EEPROM
26#if defined(CONFIG_SPD_EEPROM)
27/* Determine DDR configuration from I2C interface
28 */
29#define SPD_EEPROM_ADDRESS 0x51 /* DDR SODIMM */
30#else
31/* Manually set up DDR parameters
32 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020033#define CONFIG_SYS_DDR_SIZE 128 /* MB */
Joe Hershberger2fef4022011-10-11 23:57:29 -050034#define CONFIG_SYS_DDR_CS0_CONFIG (CSCONFIG_EN \
35 | CSCONFIG_AP \
36 | CSCONFIG_ODT_WR_CFG \
37 | CSCONFIG_ROW_BIT_13 \
38 | CSCONFIG_COL_BIT_10)
39 /* 0x80840102 */
40#define CONFIG_SYS_DDR_TIMING_0 ((0 << TIMING_CFG0_RWT_SHIFT) \
41 | (0 << TIMING_CFG0_WRT_SHIFT) \
42 | (0 << TIMING_CFG0_RRT_SHIFT) \
43 | (0 << TIMING_CFG0_WWT_SHIFT) \
44 | (2 << TIMING_CFG0_ACT_PD_EXIT_SHIFT) \
45 | (2 << TIMING_CFG0_PRE_PD_EXIT_SHIFT) \
46 | (8 << TIMING_CFG0_ODT_PD_EXIT_SHIFT) \
47 | (2 << TIMING_CFG0_MRS_CYC_SHIFT))
48 /* 0x00220802 */
49#define CONFIG_SYS_DDR_TIMING_1 ((3 << TIMING_CFG1_PRETOACT_SHIFT) \
50 | (9 << TIMING_CFG1_ACTTOPRE_SHIFT) \
51 | (3 << TIMING_CFG1_ACTTORW_SHIFT) \
52 | (5 << TIMING_CFG1_CASLAT_SHIFT) \
53 | (13 << TIMING_CFG1_REFREC_SHIFT) \
54 | (3 << TIMING_CFG1_WRREC_SHIFT) \
55 | (2 << TIMING_CFG1_ACTTOACT_SHIFT) \
56 | (2 << TIMING_CFG1_WRTORD_SHIFT))
57 /* 0x3935D322 */
58#define CONFIG_SYS_DDR_TIMING_2 ((0 << TIMING_CFG2_ADD_LAT_SHIFT) \
59 | (31 << TIMING_CFG2_CPO_SHIFT) \
60 | (2 << TIMING_CFG2_WR_LAT_DELAY_SHIFT) \
61 | (2 << TIMING_CFG2_RD_TO_PRE_SHIFT) \
62 | (2 << TIMING_CFG2_WR_DATA_DELAY_SHIFT) \
63 | (3 << TIMING_CFG2_CKE_PLS_SHIFT) \
64 | (10 << TIMING_CFG2_FOUR_ACT_SHIFT))
65 /* 0x0F9048CA */
Joe Hershberger989091a2011-10-11 23:57:13 -050066#define CONFIG_SYS_DDR_TIMING_3 0x00000000
Joe Hershberger2fef4022011-10-11 23:57:29 -050067#define CONFIG_SYS_DDR_CLK_CNTL DDR_SDRAM_CLK_CNTL_CLK_ADJUST_05
68 /* 0x02000000 */
69#define CONFIG_SYS_DDR_MODE ((0x4440 << SDRAM_MODE_ESD_SHIFT) \
70 | (0x0232 << SDRAM_MODE_SD_SHIFT))
71 /* 0x44400232 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020072#define CONFIG_SYS_DDR_MODE2 0x8000c000
Joe Hershberger2fef4022011-10-11 23:57:29 -050073#define CONFIG_SYS_DDR_INTERVAL ((800 << SDRAM_INTERVAL_REFINT_SHIFT) \
74 | (100 << SDRAM_INTERVAL_BSTOPRE_SHIFT))
75 /* 0x03200064 */
Joe Hershberger989091a2011-10-11 23:57:13 -050076#define CONFIG_SYS_DDR_CS0_BNDS 0x00000007
Joe Hershberger2fef4022011-10-11 23:57:29 -050077#define CONFIG_SYS_DDR_SDRAM_CFG (SDRAM_CFG_SREN \
78 | SDRAM_CFG_SDRAM_TYPE_DDR2 \
79 | SDRAM_CFG_32_BE)
80 /* 0x43080000 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020081#define CONFIG_SYS_DDR_SDRAM_CFG2 0x00401000
Dave Liu24c3aca2006-12-07 21:13:15 +080082#endif
83
84/*
85 * Memory test
86 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020087#undef CONFIG_SYS_DRAM_TEST /* memory test, takes time */
Dave Liu24c3aca2006-12-07 21:13:15 +080088
89/*
90 * The reserved memory
91 */
Wolfgang Denk14d0a022010-10-07 21:51:12 +020092#define CONFIG_SYS_MONITOR_BASE CONFIG_SYS_TEXT_BASE /* start of monitor */
Dave Liu24c3aca2006-12-07 21:13:15 +080093
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020094#if (CONFIG_SYS_MONITOR_BASE < CONFIG_SYS_FLASH_BASE)
95#define CONFIG_SYS_RAMBOOT
Dave Liu24c3aca2006-12-07 21:13:15 +080096#else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020097#undef CONFIG_SYS_RAMBOOT
Dave Liu24c3aca2006-12-07 21:13:15 +080098#endif
99
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200100/* CONFIG_SYS_MONITOR_LEN must be a multiple of CONFIG_ENV_SECT_SIZE */
Kevin Hao16c8c172016-07-08 11:25:14 +0800101#define CONFIG_SYS_MONITOR_LEN (512 * 1024) /* Reserve 512 kB for Mon */
Timur Tabi3b6b2562012-03-17 17:44:00 -0500102#define CONFIG_SYS_MALLOC_LEN (256 * 1024) /* Reserved for malloc */
Dave Liu24c3aca2006-12-07 21:13:15 +0800103
104/*
105 * Initial RAM Base Address Setup
106 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200107#define CONFIG_SYS_INIT_RAM_LOCK 1
Joe Hershberger989091a2011-10-11 23:57:13 -0500108#define CONFIG_SYS_INIT_RAM_ADDR 0xE6000000 /* Initial RAM addr */
109#define CONFIG_SYS_INIT_RAM_SIZE 0x1000 /* Size of used area in RAM */
110#define CONFIG_SYS_GBL_DATA_OFFSET \
111 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
Dave Liu24c3aca2006-12-07 21:13:15 +0800112
113/*
Dave Liu24c3aca2006-12-07 21:13:15 +0800114 * FLASH on the Local Bus
115 */
Joe Hershberger989091a2011-10-11 23:57:13 -0500116#define CONFIG_SYS_FLASH_BASE 0xFE000000 /* FLASH base address */
117#define CONFIG_SYS_FLASH_SIZE 16 /* FLASH size is 16M */
Dave Liu24c3aca2006-12-07 21:13:15 +0800118
Dave Liu24c3aca2006-12-07 21:13:15 +0800119
Joe Hershberger989091a2011-10-11 23:57:13 -0500120#define CONFIG_SYS_MAX_FLASH_BANKS 1 /* number of banks */
121#define CONFIG_SYS_MAX_FLASH_SECT 128 /* sectors per device */
Dave Liu24c3aca2006-12-07 21:13:15 +0800122
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200123#undef CONFIG_SYS_FLASH_CHECKSUM
Dave Liu24c3aca2006-12-07 21:13:15 +0800124
125/*
126 * BCSR on the Local Bus
127 */
Joe Hershberger989091a2011-10-11 23:57:13 -0500128#define CONFIG_SYS_BCSR 0xF8000000
129 /* Access window base at BCSR base */
Dave Liu24c3aca2006-12-07 21:13:15 +0800130
Dave Liu24c3aca2006-12-07 21:13:15 +0800131
132/*
133 * Windows to access PIB via local bus
134 */
Joe Hershberger7d6a0982011-10-11 23:57:30 -0500135 /* PIB window base 0xF8008000 */
136#define CONFIG_SYS_PIB_BASE 0xF8008000
137#define CONFIG_SYS_PIB_WINDOW_SIZE (32 * 1024)
Dave Liu24c3aca2006-12-07 21:13:15 +0800138
139/*
140 * CS2 on Local Bus, to PIB
141 */
Mario Sixa8f97532019-01-21 09:18:01 +0100142
Dave Liu24c3aca2006-12-07 21:13:15 +0800143
144/*
145 * CS3 on Local Bus, to PIB
146 */
Mario Sixa8f97532019-01-21 09:18:01 +0100147
Dave Liu24c3aca2006-12-07 21:13:15 +0800148
149/*
150 * Serial Port
151 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200152#define CONFIG_SYS_NS16550_SERIAL
153#define CONFIG_SYS_NS16550_REG_SIZE 1
154#define CONFIG_SYS_NS16550_CLK get_bus_freq(0)
Dave Liu24c3aca2006-12-07 21:13:15 +0800155
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200156#define CONFIG_SYS_BAUDRATE_TABLE \
Joe Hershberger989091a2011-10-11 23:57:13 -0500157 {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 115200}
Dave Liu24c3aca2006-12-07 21:13:15 +0800158
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200159#define CONFIG_SYS_NS16550_COM1 (CONFIG_SYS_IMMR+0x4500)
160#define CONFIG_SYS_NS16550_COM2 (CONFIG_SYS_IMMR+0x4600)
Dave Liu24c3aca2006-12-07 21:13:15 +0800161
Dave Liu24c3aca2006-12-07 21:13:15 +0800162/* I2C */
Heiko Schocher00f792e2012-10-24 13:48:22 +0200163#define CONFIG_SYS_I2C
164#define CONFIG_SYS_I2C_FSL
165#define CONFIG_SYS_FSL_I2C_SPEED 400000
166#define CONFIG_SYS_FSL_I2C_SLAVE 0x7F
167#define CONFIG_SYS_FSL_I2C_OFFSET 0x3000
168#define CONFIG_SYS_I2C_NOPROBES { {0, 0x51} }
Dave Liu24c3aca2006-12-07 21:13:15 +0800169
170/*
171 * Config on-board RTC
172 */
173#define CONFIG_RTC_DS1374 /* use ds1374 rtc via i2c */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200174#define CONFIG_SYS_I2C_RTC_ADDR 0x68 /* at address 0x68 */
Dave Liu24c3aca2006-12-07 21:13:15 +0800175
176/*
177 * General PCI
178 * Addresses are mapped 1-1.
179 */
Kim Phillips9993e192009-07-18 18:42:13 -0500180#define CONFIG_SYS_PCI1_MEM_BASE 0x80000000
181#define CONFIG_SYS_PCI1_MEM_PHYS CONFIG_SYS_PCI1_MEM_BASE
182#define CONFIG_SYS_PCI1_MEM_SIZE 0x10000000 /* 256M */
183#define CONFIG_SYS_PCI1_MMIO_BASE 0x90000000
184#define CONFIG_SYS_PCI1_MMIO_PHYS CONFIG_SYS_PCI1_MMIO_BASE
185#define CONFIG_SYS_PCI1_MMIO_SIZE 0x10000000 /* 256M */
186#define CONFIG_SYS_PCI1_IO_BASE 0x00000000
187#define CONFIG_SYS_PCI1_IO_PHYS 0xE0300000
188#define CONFIG_SYS_PCI1_IO_SIZE 0x100000 /* 1M */
Dave Liu24c3aca2006-12-07 21:13:15 +0800189
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200190#define CONFIG_SYS_PCI_SLV_MEM_LOCAL CONFIG_SYS_SDRAM_BASE
191#define CONFIG_SYS_PCI_SLV_MEM_BUS 0x00000000
192#define CONFIG_SYS_PCI_SLV_MEM_SIZE 0x80000000
Dave Liu24c3aca2006-12-07 21:13:15 +0800193
Dave Liu24c3aca2006-12-07 21:13:15 +0800194#ifdef CONFIG_PCI
Gabor Juhos842033e2013-05-30 07:06:12 +0000195#define CONFIG_PCI_INDIRECT_BRIDGE
Dave Liu24c3aca2006-12-07 21:13:15 +0800196
Kim Phillips9993e192009-07-18 18:42:13 -0500197#define CONFIG_83XX_PCI_STREAMING
Dave Liu24c3aca2006-12-07 21:13:15 +0800198
Dave Liu24c3aca2006-12-07 21:13:15 +0800199#undef CONFIG_PCI_SCAN_SHOW /* show pci devices on startup */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200200#define CONFIG_SYS_PCI_SUBSYS_VENDORID 0x1957 /* Freescale */
Dave Liu24c3aca2006-12-07 21:13:15 +0800201
202#endif /* CONFIG_PCI */
203
Dave Liu24c3aca2006-12-07 21:13:15 +0800204/*
205 * QE UEC ethernet configuration
206 */
207#define CONFIG_UEC_ETH
Kim Phillips78b7a8e2010-07-26 18:34:57 -0500208#define CONFIG_ETHPRIME "UEC0"
Dave Liu24c3aca2006-12-07 21:13:15 +0800209
210#define CONFIG_UEC_ETH1 /* ETH3 */
211
212#ifdef CONFIG_UEC_ETH1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200213#define CONFIG_SYS_UEC1_UCC_NUM 2 /* UCC3 */
214#define CONFIG_SYS_UEC1_RX_CLK QE_CLK9
215#define CONFIG_SYS_UEC1_TX_CLK QE_CLK10
216#define CONFIG_SYS_UEC1_ETH_TYPE FAST_ETH
217#define CONFIG_SYS_UEC1_PHY_ADDR 3
Andy Fleming865ff852011-04-13 00:37:12 -0500218#define CONFIG_SYS_UEC1_INTERFACE_TYPE PHY_INTERFACE_MODE_MII
Heiko Schocher582c55a2010-01-20 09:04:28 +0100219#define CONFIG_SYS_UEC1_INTERFACE_SPEED 100
Dave Liu24c3aca2006-12-07 21:13:15 +0800220#endif
221
222#define CONFIG_UEC_ETH2 /* ETH4 */
223
224#ifdef CONFIG_UEC_ETH2
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200225#define CONFIG_SYS_UEC2_UCC_NUM 3 /* UCC4 */
226#define CONFIG_SYS_UEC2_RX_CLK QE_CLK7
227#define CONFIG_SYS_UEC2_TX_CLK QE_CLK8
228#define CONFIG_SYS_UEC2_ETH_TYPE FAST_ETH
229#define CONFIG_SYS_UEC2_PHY_ADDR 4
Andy Fleming865ff852011-04-13 00:37:12 -0500230#define CONFIG_SYS_UEC2_INTERFACE_TYPE PHY_INTERFACE_MODE_MII
Heiko Schocher582c55a2010-01-20 09:04:28 +0100231#define CONFIG_SYS_UEC2_INTERFACE_SPEED 100
Dave Liu24c3aca2006-12-07 21:13:15 +0800232#endif
233
234/*
235 * Environment
236 */
Dave Liu24c3aca2006-12-07 21:13:15 +0800237
238#define CONFIG_LOADS_ECHO 1 /* echo on for serial download */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200239#define CONFIG_SYS_LOADS_BAUD_CHANGE 1 /* allow baudrate change */
Dave Liu24c3aca2006-12-07 21:13:15 +0800240
Jon Loeliger8ea54992007-07-04 22:30:06 -0500241/*
Jon Loeliger079a1362007-07-10 10:12:10 -0500242 * BOOTP options
243 */
244#define CONFIG_BOOTP_BOOTFILESIZE
Jon Loeliger079a1362007-07-10 10:12:10 -0500245
Dave Liu24c3aca2006-12-07 21:13:15 +0800246#undef CONFIG_WATCHDOG /* watchdog disabled */
247
248/*
249 * Miscellaneous configurable options
250 */
Joe Hershberger989091a2011-10-11 23:57:13 -0500251#define CONFIG_SYS_LOAD_ADDR 0x2000000 /* default load address */
Dave Liu24c3aca2006-12-07 21:13:15 +0800252
Dave Liu24c3aca2006-12-07 21:13:15 +0800253/*
254 * For booting Linux, the board info and command line data
Ira W. Snyder9f530d52010-09-10 15:42:32 -0700255 * have to be in the first 256 MB of memory, since this is
Dave Liu24c3aca2006-12-07 21:13:15 +0800256 * the maximum mapped by the Linux kernel during initialization.
257 */
Joe Hershberger989091a2011-10-11 23:57:13 -0500258 /* Initial Memory map for Linux */
259#define CONFIG_SYS_BOOTMAPSZ (256 << 20)
Kevin Hao63865272016-07-08 11:25:15 +0800260#define CONFIG_SYS_BOOTM_LEN (64 << 20) /* Increase max gunzip size */
Dave Liu24c3aca2006-12-07 21:13:15 +0800261
Jon Loeliger8ea54992007-07-04 22:30:06 -0500262#if defined(CONFIG_CMD_KGDB)
Dave Liu24c3aca2006-12-07 21:13:15 +0800263#define CONFIG_KGDB_BAUDRATE 230400 /* speed of kgdb serial port */
Dave Liu24c3aca2006-12-07 21:13:15 +0800264#endif
265
Dave Liu24c3aca2006-12-07 21:13:15 +0800266#if defined(CONFIG_UEC_ETH)
Kim Phillips977b5752008-01-09 15:24:06 -0600267#define CONFIG_HAS_ETH0
Dave Liu24c3aca2006-12-07 21:13:15 +0800268#define CONFIG_HAS_ETH1
Dave Liu24c3aca2006-12-07 21:13:15 +0800269#endif
270
Kim Phillips79f516b2009-08-21 16:34:38 -0500271#define CONFIG_LOADADDR 800000 /* default location for tftp and bootm */
Dave Liu24c3aca2006-12-07 21:13:15 +0800272
Dave Liu24c3aca2006-12-07 21:13:15 +0800273#define CONFIG_EXTRA_ENV_SETTINGS \
Joe Hershberger989091a2011-10-11 23:57:13 -0500274 "netdev=eth0\0" \
275 "consoledev=ttyS0\0" \
276 "ramdiskaddr=1000000\0" \
277 "ramdiskfile=ramfs.83xx\0" \
278 "fdtaddr=780000\0" \
279 "fdtfile=mpc832x_mds.dtb\0" \
280 ""
Dave Liu24c3aca2006-12-07 21:13:15 +0800281
282#define CONFIG_NFSBOOTCOMMAND \
Joe Hershberger989091a2011-10-11 23:57:13 -0500283 "setenv bootargs root=/dev/nfs rw " \
284 "nfsroot=$serverip:$rootpath " \
285 "ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:" \
286 "$netdev:off " \
287 "console=$consoledev,$baudrate $othbootargs;" \
288 "tftp $loadaddr $bootfile;" \
289 "tftp $fdtaddr $fdtfile;" \
290 "bootm $loadaddr - $fdtaddr"
Dave Liu24c3aca2006-12-07 21:13:15 +0800291
292#define CONFIG_RAMBOOTCOMMAND \
Joe Hershberger989091a2011-10-11 23:57:13 -0500293 "setenv bootargs root=/dev/ram rw " \
294 "console=$consoledev,$baudrate $othbootargs;" \
295 "tftp $ramdiskaddr $ramdiskfile;" \
296 "tftp $loadaddr $bootfile;" \
297 "tftp $fdtaddr $fdtfile;" \
298 "bootm $loadaddr $ramdiskaddr $fdtaddr"
Dave Liu24c3aca2006-12-07 21:13:15 +0800299
Dave Liu24c3aca2006-12-07 21:13:15 +0800300#define CONFIG_BOOTCOMMAND CONFIG_NFSBOOTCOMMAND
301
302#endif /* __CONFIG_H */