5 * SPDX-License-Identifier: GPL-2.0+
12 /* ------------------------------------------------------------------------- */
14 static long int dram_size (long int, long int *, long int);
15 unsigned long ip860_get_dram_size(void);
16 unsigned long ip860_get_clk_freq (void);
17 /* ------------------------------------------------------------------------- */
19 #define _NOT_USED_ 0xFFFFFFFF
21 const uint sdram_table[] = {
23 * Single Read. (Offset 0 in UPMA RAM)
25 0x1f07fc04, 0xeeaefc04, 0x11adfc04, 0xefbbbc00,
26 0x1ff77c47, /* last */
28 * SDRAM Initialization (offset 5 in UPMA RAM)
30 * This is no UPM entry point. The following definition uses
31 * the remaining space to establish an initialization
32 * sequence, which is executed by a RUN command.
35 0x1ff77c34, 0xefeabc34, 0x1fb57c35, /* last */
37 * Burst Read. (Offset 8 in UPMA RAM)
39 0x1f07fc04, 0xeeaefc04, 0x10adfc04, 0xf0affc00,
40 0xf0affc00, 0xf1affc00, 0xefbbbc00, 0x1ff77c47, /* last */
41 _NOT_USED_, _NOT_USED_, _NOT_USED_, _NOT_USED_,
42 _NOT_USED_, _NOT_USED_, _NOT_USED_, _NOT_USED_,
44 * Single Write. (Offset 18 in UPMA RAM)
46 0x1f27fc04, 0xeeaebc00, 0x01b93c04, 0x1ff77c47, /* last */
47 _NOT_USED_, _NOT_USED_, _NOT_USED_, _NOT_USED_,
49 * Burst Write. (Offset 20 in UPMA RAM)
51 0x1f07fc04, 0xeeaebc00, 0x10ad7c00, 0xf0affc00,
52 0xf0affc00, 0xe1bbbc04, 0x1ff77c47, /* last */
54 _NOT_USED_, _NOT_USED_, _NOT_USED_, _NOT_USED_,
55 _NOT_USED_, _NOT_USED_, _NOT_USED_, _NOT_USED_,
57 * Refresh (Offset 30 in UPMA RAM)
59 0x1ff5fc84, 0xfffffc04, 0xfffffc04, 0xfffffc04,
60 0xfffffc84, 0xfffffc07, /* last */
61 _NOT_USED_, _NOT_USED_,
62 _NOT_USED_, _NOT_USED_, _NOT_USED_, _NOT_USED_,
64 * Exception. (Offset 3c in UPMA RAM)
66 0x7ffffc07, /* last */
67 _NOT_USED_, _NOT_USED_, _NOT_USED_,
71 /* ------------------------------------------------------------------------- */
72 int board_early_init_f(void)
74 volatile immap_t *immap = (immap_t *)CONFIG_SYS_IMMR;
75 volatile memctl8xx_t *memctl = &immap->im_memctl;
77 /* init BCSR chipselect line for ip860_get_clk_freq() and ip860_get_dram_size() */
78 memctl->memc_or4 = CONFIG_SYS_OR4;
79 memctl->memc_br4 = CONFIG_SYS_BR4;
85 /* ------------------------------------------------------------------------- */
88 * Check Board Identity:
90 * Test ID string (IP860...)
96 unsigned char buf[64];
101 i = getenv_f("serial#", (char *)buf, sizeof (buf));
102 s = (i > 0) ? buf : NULL;
104 if (!s || strncmp ((char *)s, "IP860", 5)) {
105 puts ("### No HW ID - assuming IP860");
107 for (e = s; *e; ++e) {
122 /* ------------------------------------------------------------------------- */
124 phys_size_t initdram (int board_type)
126 volatile immap_t *immap = (immap_t *) CONFIG_SYS_IMMR;
127 volatile memctl8xx_t *memctl = &immap->im_memctl;
131 upmconfig (UPMA, (uint *) sdram_table,
132 sizeof (sdram_table) / sizeof (uint));
135 * Preliminary prescaler for refresh
137 if (ip860_get_clk_freq() == 50000000)
139 memctl->memc_mptpr = 0x0400;
140 refresh_val = 0xC3000000;
144 memctl->memc_mptpr = 0x0200;
145 refresh_val = 0x9C000000;
149 memctl->memc_mar = 0x00000088;
152 * Map controller banks 2 to the SDRAM address
154 memctl->memc_or2 = CONFIG_SYS_OR2;
155 memctl->memc_br2 = CONFIG_SYS_BR2;
157 /* IP860 boards have only one bank SDRAM */
162 /* perform SDRAM initializsation sequence */
164 memctl->memc_mamr = 0x00804114 | refresh_val;
165 memctl->memc_mcr = 0x80004105; /* run precharge pattern from loc 5 */
167 memctl->memc_mamr = 0x00804118 | refresh_val;
168 memctl->memc_mcr = 0x80004130; /* run refresh pattern 8 times */
174 * Check SDRAM Memory Size
176 if (ip860_get_dram_size() == 16)
177 size = dram_size (refresh_val | 0x00804114, SDRAM_BASE, SDRAM_MAX_SIZE);
179 size = dram_size (refresh_val | 0x00906114, SDRAM_BASE, SDRAM_MAX_SIZE);
183 memctl->memc_or2 = ((-size) & 0xFFFF0000) | SDRAM_TIMING;
184 memctl->memc_br2 = (CONFIG_SYS_SDRAM_BASE & BR_BA_MSK) | BR_MS_UPMA | BR_V;
189 * Also, map other memory to correct position
192 #if (defined(CONFIG_SYS_OR1) && defined(CONFIG_SYS_BR1_PRELIM))
193 memctl->memc_or1 = CONFIG_SYS_OR1;
194 memctl->memc_br1 = CONFIG_SYS_BR1;
197 #if defined(CONFIG_SYS_OR3) && defined(CONFIG_SYS_BR3)
198 memctl->memc_or3 = CONFIG_SYS_OR3;
199 memctl->memc_br3 = CONFIG_SYS_BR3;
202 #if defined(CONFIG_SYS_OR4) && defined(CONFIG_SYS_BR4)
203 memctl->memc_or4 = CONFIG_SYS_OR4;
204 memctl->memc_br4 = CONFIG_SYS_BR4;
207 #if defined(CONFIG_SYS_OR5) && defined(CONFIG_SYS_BR5)
208 memctl->memc_or5 = CONFIG_SYS_OR5;
209 memctl->memc_br5 = CONFIG_SYS_BR5;
212 #if defined(CONFIG_SYS_OR6) && defined(CONFIG_SYS_BR6)
213 memctl->memc_or6 = CONFIG_SYS_OR6;
214 memctl->memc_br6 = CONFIG_SYS_BR6;
217 #if defined(CONFIG_SYS_OR7) && defined(CONFIG_SYS_BR7)
218 memctl->memc_or7 = CONFIG_SYS_OR7;
219 memctl->memc_br7 = CONFIG_SYS_BR7;
225 /* ------------------------------------------------------------------------- */
228 * Check memory range for valid RAM. A simple memory test determines
229 * the actually available RAM size between addresses `base' and
230 * `base + maxsize'. Some (not all) hardware errors are detected:
231 * - short between address lines
232 * - short between data lines
235 static long int dram_size (long int mamr_value, long int *base,
238 volatile immap_t *immap = (immap_t *) CONFIG_SYS_IMMR;
239 volatile memctl8xx_t *memctl = &immap->im_memctl;
241 memctl->memc_mamr = mamr_value;
243 return (get_ram_size(base, maxsize));
246 /* ------------------------------------------------------------------------- */
248 void reset_phy (void)
250 volatile immap_t *immr = (immap_t *) CONFIG_SYS_IMMR;
251 ulong mask = PB_ENET_RESET | PB_ENET_JABD;
254 /* Make sure PHY is not in low-power mode */
255 immr->im_cpm.cp_pbpar &= ~(mask); /* GPIO */
256 immr->im_cpm.cp_pbodr &= ~(mask); /* active output */
258 /* Set JABD low (no JABber Disable),
259 * and RESET high (Reset PHY)
261 reg = immr->im_cpm.cp_pbdat;
262 reg = (reg & ~PB_ENET_JABD) | PB_ENET_RESET;
263 immr->im_cpm.cp_pbdat = reg;
265 /* now drive outputs */
266 immr->im_cpm.cp_pbdir |= mask; /* output */
269 * Release RESET signal
271 immr->im_cpm.cp_pbdat &= ~(PB_ENET_RESET);
275 /* ------------------------------------------------------------------------- */
277 unsigned long ip860_get_clk_freq(void)
279 volatile ip860_bcsr_t *bcsr = (ip860_bcsr_t *)BCSR_BASE;
283 if ((bcsr->bd_status & 0x80) == 0x80) /* bd_rev valid ? */
284 sysclk = (bcsr->bd_rev & 0x18) >> 3;
308 /* ------------------------------------------------------------------------- */
310 unsigned long ip860_get_dram_size(void)
312 volatile ip860_bcsr_t *bcsr = (ip860_bcsr_t *)BCSR_BASE;
316 if ((bcsr->bd_status & 0x80) == 0x80) /* bd_rev valid ? */
317 dram_size = (bcsr->bd_rev & 0xE0) >> 5;
319 dram_size = 0x00; /* default is 16 MB */
340 /* ------------------------------------------------------------------------- */