2
* Copyright (c) 2008 Nuovation System Designs, LLC
3
* Grant Erickson <gerickson@nuovations.com>
5
* Copyright (c) 2007-2009 DENX Software Engineering, GmbH
6
* Stefan Roese <sr@denx.de>
8
* See file CREDITS for list of people who contributed to this
11
* This program is free software; you can redistribute it and/or
12
* modify it under the terms of the GNU General Public License as
13
* published by the Free Software Foundation; either version 2 of
14
* the License, or (at your option) any later version.
16
* This program is distributed in the hope that it will abe useful,
17
* but WITHOUT ANY WARRANTY; without even the implied warranty of
18
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19
* GNU General Public License for more details.
21
* You should have received a copy of the GNU General Public License
22
* along with this program; if not, write to the Free Software
23
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
27
* This file implements ECC initialization for PowerPC processors
28
* using the IBM SDRAM DDR1 & DDR2 controller.
36
* Since the IBM DDR controller used on 440GP/GX/EP/GR is not register
37
* compatible to the IBM DDR/2 controller used on 405EX/440SP/SPe/460EX/GT
38
* we need to make some processor dependant defines used later on by the
42
/* For 440GP/GX/EP/GR */
43
#if defined(CONFIG_SDRAM_PPC4xx_IBM_DDR)
44
#define SDRAM_MCOPT1 SDRAM_CFG0
45
#define SDRAM_MCOPT1_MCHK_MASK SDRAM_CFG0_MCHK_MASK
46
#define SDRAM_MCOPT1_MCHK_NON SDRAM_CFG0_MCHK_NON
47
#define SDRAM_MCOPT1_MCHK_GEN SDRAM_CFG0_MCHK_GEN
48
#define SDRAM_MCOPT1_MCHK_CHK SDRAM_CFG0_MCHK_CHK
49
#define SDRAM_MCOPT1_MCHK_CHK_REP SDRAM_CFG0_MCHK_CHK
50
#define SDRAM_MCOPT1_DMWD_MASK SDRAM_CFG0_DMWD_MASK
51
#define SDRAM_MCOPT1_DMWD_32 SDRAM_CFG0_DMWD_32
53
#define SDRAM_MCSTAT SDRAM0_MCSTS
54
#define SDRAM_MCSTAT_IDLE_MASK SDRAM_MCSTS_CIS
55
#define SDRAM_MCSTAT_IDLE_NOT SDRAM_MCSTS_IDLE_NOT
57
#define SDRAM_ECCES SDRAM0_ECCESR
60
void ecc_init(unsigned long * const start, unsigned long size);
61
void do_program_ecc(unsigned long tlb_word2_i_value);
63
static void inline blank_string(int size)
67
for (i = 0; i < size; i++)
69
for (i = 0; i < size; i++)
71
for (i = 0; i < size; i++)