blob: ebd5274a5650bb2da623fde2895ab122fef6664a [file] [log] [blame]
Marian Balakowiczd7a3f722006-03-14 16:24:38 +01001/*
2 * (C) Copyright 2006
3 * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4 *
5 * See file CREDITS for list of people who contributed to this
6 * project.
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public License as
10 * published by the Free Software Foundation; either version 2 of
11 * the License, or (at your option) any later version.
12 *
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
17 *
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21 * MA 02111-1307 USA
22 *
23 */
24
25#include <common.h>
26#include <ioports.h>
27#include <mpc83xx.h>
28#include <asm/mpc8349_pci.h>
29#include <i2c.h>
Ben Warren81362c12008-01-16 22:37:42 -050030#include <spi.h>
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010031#include <miiphy.h>
York Sunc3c301e2011-08-26 11:32:45 -070032#ifdef CONFIG_FSL_DDR2
33#include <asm/fsl_ddr_sdram.h>
34#else
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010035#include <spd_sdram.h>
York Sunc3c301e2011-08-26 11:32:45 -070036#endif
Jon Loeligerde9737d2008-03-04 10:03:03 -060037
Kim Phillips3204c7c2007-12-20 15:57:28 -060038#if defined(CONFIG_OF_LIBFDT)
Kim Phillips21416812007-08-15 22:30:33 -050039#include <libfdt.h>
Kim Phillips774e1b52006-11-01 00:10:40 -060040#endif
41
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010042int fixed_sdram(void);
43void sdram_init(void);
44
Peter Tyser62e73982009-05-22 17:23:24 -050045#if defined(CONFIG_DDR_ECC) && defined(CONFIG_MPC83xx)
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010046void ddr_enable_ecc(unsigned int dram_size);
47#endif
48
49int board_early_init_f (void)
50{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020051 volatile u8* bcsr = (volatile u8*)CONFIG_SYS_BCSR;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010052
53 /* Enable flash write */
54 bcsr[1] &= ~0x01;
55
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020056#ifdef CONFIG_SYS_USE_MPC834XSYS_USB_PHY
Kumar Gala4c7efd82006-04-20 13:45:32 -050057 /* Use USB PHY on SYS board */
58 bcsr[5] |= 0x02;
59#endif
60
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010061 return 0;
62}
63
64#define ns2clk(ns) (ns / (1000000000 / CONFIG_8349_CLKIN) + 1)
65
Becky Brucebd99ae72008-06-09 16:03:40 -050066phys_size_t initdram (int board_type)
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010067{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020068 volatile immap_t *im = (immap_t *)CONFIG_SYS_IMMR;
York Sunc3c301e2011-08-26 11:32:45 -070069 phys_size_t msize = 0;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010070
71 if ((im->sysconf.immrbar & IMMRBAR_BASE_ADDR) != (u32)im)
72 return -1;
73
74 /* DDR SDRAM - Main SODIMM */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +020075 im->sysconf.ddrlaw[0].bar = CONFIG_SYS_DDR_BASE & LAWBAR_BAR;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010076#if defined(CONFIG_SPD_EEPROM)
York Sunc3c301e2011-08-26 11:32:45 -070077#ifndef CONFIG_FSL_DDR2
78 msize = spd_sdram() * 1024 * 1024;
79#if defined(CONFIG_DDR_ECC) && !defined(CONFIG_ECC_INIT_VIA_DDRCONTROLLER)
80 ddr_enable_ecc(msize);
81#endif
82#else
83 msize = fsl_ddr_sdram();
84#endif
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010085#else
York Sunc3c301e2011-08-26 11:32:45 -070086 msize = fixed_sdram() * 1024 * 1024;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010087#endif
88 /*
89 * Initialize SDRAM if it is on local bus.
90 */
91 sdram_init();
92
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010093 /* return total bus SDRAM size(bytes) -- DDR */
York Sunc3c301e2011-08-26 11:32:45 -070094 return msize;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +010095}
96
97#if !defined(CONFIG_SPD_EEPROM)
98/*************************************************************************
99 * fixed sdram init -- doesn't use serial presence detect.
100 ************************************************************************/
101int fixed_sdram(void)
102{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200103 volatile immap_t *im = (immap_t *)CONFIG_SYS_IMMR;
Joe Hershberger5ade3902011-10-11 23:57:31 -0500104 u32 msize = CONFIG_SYS_DDR_SIZE;
105 u32 ddr_size = msize << 20; /* DDR size in bytes */
106 u32 ddr_size_log2 = __ilog2(ddr_size);
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100107
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200108 im->sysconf.ddrlaw[0].bar = CONFIG_SYS_DDR_SDRAM_BASE & 0xfffff000;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100109 im->sysconf.ddrlaw[0].ar = LAWAR_EN | ((ddr_size_log2 - 1) & LAWAR_SIZE);
Rafal Jaworowski4a9b6aa2006-03-16 17:46:46 +0100110
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200111#if (CONFIG_SYS_DDR_SIZE != 256)
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100112#warning Currenly any ddr size other than 256 is not supported
113#endif
Xie Xiaobo6149a5a2007-02-14 18:27:17 +0800114#ifdef CONFIG_DDR_II
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200115 im->ddr.csbnds[2].csbnds = CONFIG_SYS_DDR_CS2_BNDS;
116 im->ddr.cs_config[2] = CONFIG_SYS_DDR_CS2_CONFIG;
117 im->ddr.timing_cfg_0 = CONFIG_SYS_DDR_TIMING_0;
118 im->ddr.timing_cfg_1 = CONFIG_SYS_DDR_TIMING_1;
119 im->ddr.timing_cfg_2 = CONFIG_SYS_DDR_TIMING_2;
120 im->ddr.timing_cfg_3 = CONFIG_SYS_DDR_TIMING_3;
121 im->ddr.sdram_cfg = CONFIG_SYS_DDR_SDRAM_CFG;
122 im->ddr.sdram_cfg2 = CONFIG_SYS_DDR_SDRAM_CFG2;
123 im->ddr.sdram_mode = CONFIG_SYS_DDR_MODE;
124 im->ddr.sdram_mode2 = CONFIG_SYS_DDR_MODE2;
125 im->ddr.sdram_interval = CONFIG_SYS_DDR_INTERVAL;
126 im->ddr.sdram_clk_cntl = CONFIG_SYS_DDR_CLK_CNTL;
Xie Xiaobo6149a5a2007-02-14 18:27:17 +0800127#else
Joe Hershberger5ade3902011-10-11 23:57:31 -0500128
129#if ((CONFIG_SYS_DDR_SDRAM_BASE & 0x00FFFFFF) != 0)
130#warning Chip select bounds is only configurable in 16MB increments
131#endif
132 im->ddr.csbnds[2].csbnds =
133 ((CONFIG_SYS_DDR_SDRAM_BASE >> CSBNDS_SA_SHIFT) & CSBNDS_SA) |
134 (((CONFIG_SYS_DDR_SDRAM_BASE + ddr_size - 1) >>
135 CSBNDS_EA_SHIFT) & CSBNDS_EA);
136 im->ddr.cs_config[2] = CONFIG_SYS_DDR_CS2_CONFIG;
Rafal Jaworowski4a9b6aa2006-03-16 17:46:46 +0100137
Wolfgang Denkebd3deb2006-04-16 10:51:58 +0200138 /* currently we use only one CS, so disable the other banks */
Rafal Jaworowski4a9b6aa2006-03-16 17:46:46 +0100139 im->ddr.cs_config[0] = 0;
140 im->ddr.cs_config[1] = 0;
141 im->ddr.cs_config[3] = 0;
142
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200143 im->ddr.timing_cfg_1 = CONFIG_SYS_DDR_TIMING_1;
144 im->ddr.timing_cfg_2 = CONFIG_SYS_DDR_TIMING_2;
Wolfgang Denkebd3deb2006-04-16 10:51:58 +0200145
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100146 im->ddr.sdram_cfg =
147 SDRAM_CFG_SREN
148#if defined(CONFIG_DDR_2T_TIMING)
149 | SDRAM_CFG_2T_EN
150#endif
151 | 2 << SDRAM_CFG_SDRAM_TYPE_SHIFT;
Rafal Jaworowski4a9b6aa2006-03-16 17:46:46 +0100152#if defined (CONFIG_DDR_32BIT)
153 /* for 32-bit mode burst length is 8 */
154 im->ddr.sdram_cfg |= (SDRAM_CFG_32_BE | SDRAM_CFG_8_BE);
155#endif
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200156 im->ddr.sdram_mode = CONFIG_SYS_DDR_MODE;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100157
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200158 im->ddr.sdram_interval = CONFIG_SYS_DDR_INTERVAL;
Xie Xiaobo6149a5a2007-02-14 18:27:17 +0800159#endif
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100160 udelay(200);
161
Rafal Jaworowski4a9b6aa2006-03-16 17:46:46 +0100162 /* enable DDR controller */
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100163 im->ddr.sdram_cfg |= SDRAM_CFG_MEM_EN;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100164 return msize;
165}
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200166#endif/*!CONFIG_SYS_SPD_EEPROM*/
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100167
168
169int checkboard (void)
170{
Ira W. Snyder4adfd022008-08-22 11:00:15 -0700171 /*
172 * Warning: do not read the BCSR registers here
173 *
174 * There is a timing bug in the 8349E and 8349EA BCSR code
175 * version 1.2 (read from BCSR 11) that will cause the CFI
176 * flash initialization code to overwrite BCSR 0, disabling
177 * the serial ports and gigabit ethernet
178 */
179
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100180 puts("Board: Freescale MPC8349EMDS\n");
181 return 0;
182}
183
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100184/*
185 * if MPC8349EMDS is soldered with SDRAM
186 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200187#if defined(CONFIG_SYS_BR2_PRELIM) \
188 && defined(CONFIG_SYS_OR2_PRELIM) \
189 && defined(CONFIG_SYS_LBLAWBAR2_PRELIM) \
190 && defined(CONFIG_SYS_LBLAWAR2_PRELIM)
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100191/*
192 * Initialize SDRAM memory on the Local Bus.
193 */
194
195void sdram_init(void)
196{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200197 volatile immap_t *immap = (immap_t *)CONFIG_SYS_IMMR;
Becky Bruce0d4cee12010-06-17 11:37:20 -0500198 volatile fsl_lbc_t *lbc = &immap->im_lbc;
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200199 uint *sdram_addr = (uint *)CONFIG_SYS_LBC_SDRAM_BASE;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100200
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100201 /*
202 * Setup SDRAM Base and Option Registers, already done in cpu_init.c
203 */
204
205 /* setup mtrpt, lsrt and lbcr for LB bus */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200206 lbc->lbcr = CONFIG_SYS_LBC_LBCR;
207 lbc->mrtpr = CONFIG_SYS_LBC_MRTPR;
208 lbc->lsrt = CONFIG_SYS_LBC_LSRT;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100209 asm("sync");
210
211 /*
212 * Configure the SDRAM controller Machine Mode Register.
213 */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200214 lbc->lsdmr = CONFIG_SYS_LBC_LSDMR_5; /* 0x40636733; normal operation */
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100215
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200216 lbc->lsdmr = CONFIG_SYS_LBC_LSDMR_1; /* 0x68636733; precharge all the banks */
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100217 asm("sync");
218 *sdram_addr = 0xff;
219 udelay(100);
220
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200221 lbc->lsdmr = CONFIG_SYS_LBC_LSDMR_2; /* 0x48636733; auto refresh */
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100222 asm("sync");
223 /*1 times*/
224 *sdram_addr = 0xff;
225 udelay(100);
226 /*2 times*/
227 *sdram_addr = 0xff;
228 udelay(100);
229 /*3 times*/
230 *sdram_addr = 0xff;
231 udelay(100);
232 /*4 times*/
233 *sdram_addr = 0xff;
234 udelay(100);
235 /*5 times*/
236 *sdram_addr = 0xff;
237 udelay(100);
238 /*6 times*/
239 *sdram_addr = 0xff;
240 udelay(100);
241 /*7 times*/
242 *sdram_addr = 0xff;
243 udelay(100);
244 /*8 times*/
245 *sdram_addr = 0xff;
246 udelay(100);
247
248 /* 0x58636733; mode register write operation */
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200249 lbc->lsdmr = CONFIG_SYS_LBC_LSDMR_4;
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100250 asm("sync");
251 *sdram_addr = 0xff;
252 udelay(100);
253
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200254 lbc->lsdmr = CONFIG_SYS_LBC_LSDMR_5; /* 0x40636733; normal operation */
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100255 asm("sync");
256 *sdram_addr = 0xff;
257 udelay(100);
258}
259#else
260void sdram_init(void)
261{
Marian Balakowiczd7a3f722006-03-14 16:24:38 +0100262}
263#endif
Marian Balakowicz52ee4bd2006-03-16 15:19:35 +0100264
Ben Warren81362c12008-01-16 22:37:42 -0500265/*
266 * The following are used to control the SPI chip selects for the SPI command.
267 */
Ben Warren20582da2008-06-08 23:28:33 -0700268#ifdef CONFIG_MPC8XXX_SPI
Ben Warren81362c12008-01-16 22:37:42 -0500269
270#define SPI_CS_MASK 0x80000000
271
Haavard Skinnemoend74084a2008-05-16 11:10:31 +0200272int spi_cs_is_valid(unsigned int bus, unsigned int cs)
273{
274 return bus == 0 && cs == 0;
275}
276
277void spi_cs_activate(struct spi_slave *slave)
Ben Warren81362c12008-01-16 22:37:42 -0500278{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200279 volatile gpio83xx_t *iopd = &((immap_t *)CONFIG_SYS_IMMR)->gpio[0];
Ben Warren81362c12008-01-16 22:37:42 -0500280
Haavard Skinnemoend74084a2008-05-16 11:10:31 +0200281 iopd->dat &= ~SPI_CS_MASK;
Ben Warren81362c12008-01-16 22:37:42 -0500282}
283
Haavard Skinnemoend74084a2008-05-16 11:10:31 +0200284void spi_cs_deactivate(struct spi_slave *slave)
285{
Jean-Christophe PLAGNIOL-VILLARD03836942008-10-16 15:01:15 +0200286 volatile gpio83xx_t *iopd = &((immap_t *)CONFIG_SYS_IMMR)->gpio[0];
Ben Warren81362c12008-01-16 22:37:42 -0500287
Haavard Skinnemoend74084a2008-05-16 11:10:31 +0200288 iopd->dat |= SPI_CS_MASK;
289}
Ben Warren81362c12008-01-16 22:37:42 -0500290#endif /* CONFIG_HARD_SPI */
291
Kim Phillips21416812007-08-15 22:30:33 -0500292#if defined(CONFIG_OF_BOARD_SETUP)
293void ft_board_setup(void *blob, bd_t *bd)
Kim Phillips774e1b52006-11-01 00:10:40 -0600294{
Kim Phillips21416812007-08-15 22:30:33 -0500295 ft_cpu_setup(blob, bd);
296#ifdef CONFIG_PCI
297 ft_pci_setup(blob, bd);
298#endif
Kim Phillips774e1b52006-11-01 00:10:40 -0600299}
300#endif