blob: 39a36779bc4ac8a782dfac36268720035532ae84 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Heiko Schocher3c773bb2014-01-25 07:53:48 +01002/*
3 * (C) Copyright 2013
4 * Heiko Schocher, DENX Software Engineering, hs@denx.de.
5 *
6 * Based on:
7 * Copyright (c) 2011 IDS GmbH, Germany
8 * Sergej Stepanov <ste@ids.de>
Heiko Schocher3c773bb2014-01-25 07:53:48 +01009 */
10
11#ifndef __CONFIG_H
12#define __CONFIG_H
13
Simon Glassfb64e362020-05-10 11:40:09 -060014#include <linux/stringify.h>
15
Heiko Schocher3c773bb2014-01-25 07:53:48 +010016/*
17 * High Level Configuration Options
18 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +010019
Heiko Schocher3c773bb2014-01-25 07:53:48 +010020#define CONFIG_SYS_SICRH 0x00000000
21#define CONFIG_SYS_SICRL (SICRL_LBC | SICRL_SPI_D)
22
23#define CONFIG_HWCONFIG
24
Heiko Schocher3c773bb2014-01-25 07:53:48 +010025/*
26 * Definitions for initial stack pointer and data area (in DCACHE )
27 */
28#define CONFIG_SYS_INIT_RAM_LOCK
29#define CONFIG_SYS_INIT_RAM_ADDR 0xFD000000
30#define CONFIG_SYS_INIT_RAM_SIZE 0x1000 /* End of used area in DPRAM */
Heiko Schocher3c773bb2014-01-25 07:53:48 +010031
32/*
Heiko Schocher3c773bb2014-01-25 07:53:48 +010033 * Internal Definitions
34 */
35/*
36 * DDR Setup
37 */
Mario Sixc9f92772019-01-21 09:18:15 +010038#define CONFIG_SYS_SDRAM_BASE 0x00000000
Heiko Schocher3c773bb2014-01-25 07:53:48 +010039
40/*
41 * Manually set up DDR parameters,
42 * as this board has not the SPD connected to I2C.
43 */
44#define CONFIG_SYS_DDR_SIZE 256 /* MB */
45#define CONFIG_SYS_DDR_CONFIG (CSCONFIG_EN |\
46 0x00010000 |\
47 CSCONFIG_ROW_BIT_13 |\
48 CSCONFIG_COL_BIT_10)
49
50#define CONFIG_SYS_DDR_CONFIG_256 (CONFIG_SYS_DDR_CONFIG | \
51 CSCONFIG_BANK_BIT_3)
52
53#define CONFIG_SYS_DDR_TIMING_3 (1 << 16) /* ext refrec */
54#define CONFIG_SYS_DDR_TIMING_0 ((3 << TIMING_CFG0_RWT_SHIFT) |\
55 (3 << TIMING_CFG0_WRT_SHIFT) |\
56 (3 << TIMING_CFG0_RRT_SHIFT) |\
57 (3 << TIMING_CFG0_WWT_SHIFT) |\
58 (6 << TIMING_CFG0_ACT_PD_EXIT_SHIFT) |\
59 (2 << TIMING_CFG0_PRE_PD_EXIT_SHIFT) |\
60 (8 << TIMING_CFG0_ODT_PD_EXIT_SHIFT) | \
61 (2 << TIMING_CFG0_MRS_CYC_SHIFT))
62#define CONFIG_SYS_DDR_TIMING_1 ((4 << TIMING_CFG1_PRETOACT_SHIFT) |\
63 (12 << TIMING_CFG1_ACTTOPRE_SHIFT) |\
64 (4 << TIMING_CFG1_ACTTORW_SHIFT) |\
65 (7 << TIMING_CFG1_CASLAT_SHIFT) |\
66 (4 << TIMING_CFG1_REFREC_SHIFT) |\
67 (4 << TIMING_CFG1_WRREC_SHIFT) |\
68 (2 << TIMING_CFG1_ACTTOACT_SHIFT) |\
69 (2 << TIMING_CFG1_WRTORD_SHIFT))
70#define CONFIG_SYS_DDR_TIMING_2 ((1 << TIMING_CFG2_ADD_LAT_SHIFT) |\
71 (5 << TIMING_CFG2_CPO_SHIFT) |\
72 (4 << TIMING_CFG2_WR_LAT_DELAY_SHIFT) |\
73 (2 << TIMING_CFG2_RD_TO_PRE_SHIFT) |\
74 (0 << TIMING_CFG2_WR_DATA_DELAY_SHIFT) |\
75 (1 << TIMING_CFG2_CKE_PLS_SHIFT) |\
76 (6 << TIMING_CFG2_FOUR_ACT_SHIFT))
77
78#define CONFIG_SYS_DDR_INTERVAL ((0x800 << SDRAM_INTERVAL_REFINT_SHIFT) |\
79 (0x800 << SDRAM_INTERVAL_BSTOPRE_SHIFT))
80
81#define CONFIG_SYS_SDRAM_CFG (SDRAM_CFG_SREN |\
82 SDRAM_CFG_2T_EN | SDRAM_CFG_HSE |\
83 SDRAM_CFG_DBW_32 |\
84 SDRAM_CFG_SDRAM_TYPE_DDR2)
85
86#define CONFIG_SYS_SDRAM_CFG2 0x00401000
87#define CONFIG_SYS_DDR_MODE ((0x0448 << SDRAM_MODE_ESD_SHIFT) |\
88 (0x0242 << SDRAM_MODE_SD_SHIFT))
89#define CONFIG_SYS_DDR_MODE_2 0x00000000
90#define CONFIG_SYS_DDR_CLK_CNTL DDR_SDRAM_CLK_CNTL_CLK_ADJUST_075
91#define CONFIG_SYS_DDRCDR_VALUE (DDRCDR_EN |\
92 DDRCDR_PZ_NOMZ |\
93 DDRCDR_NZ_NOMZ |\
94 DDRCDR_ODT |\
95 DDRCDR_M_ODR |\
96 DDRCDR_Q_DRN)
97
98/*
99 * on-board devices
100 */
101#define CONFIG_TSEC1
102#define CONFIG_TSEC2
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100103
104/*
105 * NOR FLASH setup
106 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100107#define CONFIG_FLASH_SHOW_PROGRESS 50
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100108
109#define CONFIG_SYS_FLASH_BASE 0xFF800000
110#define CONFIG_SYS_FLASH_SIZE 8
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100111
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100112
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100113#define CONFIG_SYS_MAX_FLASH_SECT 128
114
115#define CONFIG_SYS_FLASH_ERASE_TOUT 60000
116#define CONFIG_SYS_FLASH_WRITE_TOUT 500
117
118/*
119 * NAND FLASH setup
120 */
121#define CONFIG_SYS_NAND_BASE 0xE1000000
122#define CONFIG_SYS_MAX_NAND_DEVICE 1
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100123#define NAND_CACHE_PAGES 64
124
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100125
126/*
127 * MRAM setup
128 */
129#define CONFIG_SYS_MRAM_BASE 0xE2000000
130#define CONFIG_SYS_MRAM_SIZE 0x20000 /* 128 Kb */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100131
132#define CONFIG_SYS_OR_TIMING_MRAM
133
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100134
135/*
136 * CPLD setup
137 */
138#define CONFIG_SYS_CPLD_BASE 0xE3000000
139#define CONFIG_SYS_CPLD_SIZE 0x8000
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100140
141#define CONFIG_SYS_OR_TIMING_MRAM
142
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100143
144/*
145 * HW-Watchdog
146 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100147#define CONFIG_SYS_WATCHDOG_VALUE 0xFFFF
148
149/*
150 * I2C setup
151 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100152#define CONFIG_SYS_I2C_RTC_ADDR 0x51
153
154/*
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100155 * Ethernet setup
156 */
157#ifdef CONFIG_TSEC1
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100158#define CONFIG_TSEC1_NAME "TSEC0"
159#define CONFIG_SYS_TSEC1_OFFSET 0x24000
160#define TSEC1_PHY_ADDR 0x1
161#define TSEC1_FLAGS TSEC_GIGABIT
162#define TSEC1_PHYIDX 0
163#endif
164
165#ifdef CONFIG_TSEC2
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100166#define CONFIG_TSEC2_NAME "TSEC1"
167#define CONFIG_SYS_TSEC2_OFFSET 0x25000
168#define TSEC2_PHY_ADDR 0x3
169#define TSEC2_FLAGS TSEC_GIGABIT
170#define TSEC2_PHYIDX 0
171#endif
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100172
173/*
174 * Serial Port
175 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100176#define CONFIG_SYS_NS16550_SERIAL
177#define CONFIG_SYS_NS16550_REG_SIZE 1
178
179#define CONFIG_SYS_BAUDRATE_TABLE \
180 {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 115200}
181#define CONFIG_SYS_NS16550_COM1 (CONFIG_SYS_IMMR + 0x4500)
182#define CONFIG_SYS_NS16550_COM2 (CONFIG_SYS_IMMR + 0x4600)
Mario Sixcd677ca2019-01-21 09:17:52 +0100183#define CONFIG_SYS_NS16550_CLK (get_bus_freq(0))
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100184
185#define CONFIG_HAS_FSL_DR_USB
186#define CONFIG_SYS_SCCR_USBDRCM 3
187
188/*
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100189 * U-Boot environment setup
190 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100191
192/*
193 * The reserved memory
194 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100195#define CONFIG_SYS_MONITOR_LEN (768 * 1024)
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100196
197/*
198 * Environment Configuration
199 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100200
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100201#define CONFIG_NETDEV eth1
Mario Six790d8442018-03-28 14:38:20 +0200202#define CONFIG_HOSTNAME "ids8313"
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100203#define CONFIG_ROOTPATH "/opt/eldk-4.2/ppc_6xx"
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100204#define CONFIG_UBOOTPATH "ids8313/u-boot.bin"
205#define CONFIG_FDTFILE "ids8313/ids8313.dtb"
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100206#define CONFIG_ENV_FLAGS_LIST_STATIC "ethaddr:mo,eth1addr:mo"
207
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100208/* Initial Memory map for Linux*/
209#define CONFIG_SYS_BOOTMAPSZ (256 << 20)
210
211/*
212 * Miscellaneous configurable options
213 */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100214
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100215#define CONFIG_LOADS_ECHO
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100216#undef CONFIG_SYS_LOADS_BAUD_CHANGE
217
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100218/* mtdparts command line support */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100219
220#define CONFIG_EXTRA_ENV_SETTINGS \
221 "netdev=" __stringify(CONFIG_NETDEV) "\0" \
222 "ethprime=TSEC1\0" \
223 "uboot=" __stringify(CONFIG_UBOOTPATH) "\0" \
224 "tftpflash=tftpboot ${loadaddr} ${uboot}; " \
225 "protect off " __stringify(CONFIG_SYS_TEXT_BASE) \
226 " +${filesize}; " \
227 "erase " __stringify(CONFIG_SYS_TEXT_BASE) \
228 " +${filesize}; " \
229 "cp.b ${loadaddr} " __stringify(CONFIG_SYS_TEXT_BASE) \
230 " ${filesize}; " \
231 "protect on " __stringify(CONFIG_SYS_TEXT_BASE) \
232 " +${filesize}; " \
233 "cmp.b ${loadaddr} " __stringify(CONFIG_SYS_TEXT_BASE) \
234 " ${filesize}\0" \
235 "console=ttyS0\0" \
236 "fdtaddr=0x780000\0" \
237 "kernel_addr=ff800000\0" \
238 "fdtfile=" __stringify(CONFIG_FDTFILE) "\0" \
239 "setbootargs=setenv bootargs " \
240 "root=${rootdev} rw console=${console}," \
241 "${baudrate} ${othbootargs}\0" \
242 "setipargs=setenv bootargs root=${rootdev} rw " \
243 "nfsroot=${serverip}:${rootpath} " \
244 "ip=${ipaddr}:${serverip}:${gatewayip}:" \
245 "${netmask}:${hostname}:${netdev}:off " \
246 "console=${console},${baudrate} ${othbootargs}\0" \
247 "addmtd=setenv bootargs ${bootargs} ${mtdparts}\0" \
Tom Rini5ad8e112017-10-22 17:55:07 -0400248 "mtdids=" CONFIG_MTDIDS_DEFAULT "\0" \
249 "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0" \
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100250 "\0"
251
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100252/* UBI Support */
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100253
Heiko Schocher3c773bb2014-01-25 07:53:48 +0100254#endif /* __CONFIG_H */