]> git.karo-electronics.de Git - karo-tx-uboot.git/blob - board/sbc8548/ddr.c
sbc8548: relocate fixed ddr init code to ddr.c file
[karo-tx-uboot.git] / board / sbc8548 / ddr.c
1 /*
2  * Copyright 2008 Freescale Semiconductor, Inc.
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * Version 2 as published by the Free Software Foundation.
7  */
8
9 #include <common.h>
10
11 #include <asm/fsl_ddr_sdram.h>
12 #include <asm/fsl_ddr_dimm_params.h>
13
14 void fsl_ddr_board_options(memctl_options_t *popts,
15                                 dimm_params_t *pdimm,
16                                 unsigned int ctrl_num)
17 {
18         /*
19          * Factors to consider for clock adjust:
20          *      - number of chips on bus
21          *      - position of slot
22          *      - DDR1 vs. DDR2?
23          *      - ???
24          *
25          * This needs to be determined on a board-by-board basis.
26          *      0110    3/4 cycle late
27          *      0111    7/8 cycle late
28          */
29         popts->clk_adjust = 7;
30
31         /*
32          * Factors to consider for CPO:
33          *      - frequency
34          *      - ddr1 vs. ddr2
35          */
36         popts->cpo_override = 10;
37
38         /*
39          * Factors to consider for write data delay:
40          *      - number of DIMMs
41          *
42          * 1 = 1/4 clock delay
43          * 2 = 1/2 clock delay
44          * 3 = 3/4 clock delay
45          * 4 = 1   clock delay
46          * 5 = 5/4 clock delay
47          * 6 = 3/2 clock delay
48          */
49         popts->write_data_delay = 3;
50
51         /*
52          * Factors to consider for half-strength driver enable:
53          *      - number of DIMMs installed
54          */
55         popts->half_strength_driver_enable = 0;
56 }
57
58 #if !defined(CONFIG_SPD_EEPROM)
59 /*
60  *  fixed_sdram init -- doesn't use serial presence detect.
61  *  Assumes 256MB DDR2 SDRAM SODIMM, without ECC, running at DDR400 speed.
62  */
63 phys_size_t fixed_sdram(void)
64 {
65         volatile ccsr_ddr_t *ddr = (void *)(CONFIG_SYS_MPC85xx_DDR_ADDR);
66
67         out_be32(&ddr->cs0_bnds,        0x0000007f);
68         out_be32(&ddr->cs1_bnds,        0x008000ff);
69         out_be32(&ddr->cs2_bnds,        0x00000000);
70         out_be32(&ddr->cs3_bnds,        0x00000000);
71
72         out_be32(&ddr->cs0_config,      0x80010101);
73         out_be32(&ddr->cs1_config,      0x80010101);
74         out_be32(&ddr->cs2_config,      0x00000000);
75         out_be32(&ddr->cs3_config,      0x00000000);
76
77         out_be32(&ddr->timing_cfg_3,    0x00000000);
78         out_be32(&ddr->timing_cfg_0,    0x00220802);
79         out_be32(&ddr->timing_cfg_1,    0x38377322);
80         out_be32(&ddr->timing_cfg_2,    0x0fa044C7);
81
82         out_be32(&ddr->sdram_cfg,       0x4300C000);
83         out_be32(&ddr->sdram_cfg_2,     0x24401000);
84
85         out_be32(&ddr->sdram_mode,      0x23C00542);
86         out_be32(&ddr->sdram_mode_2,    0x00000000);
87
88         out_be32(&ddr->sdram_interval,  0x05080100);
89         out_be32(&ddr->sdram_md_cntl,   0x00000000);
90         out_be32(&ddr->sdram_data_init, 0x00000000);
91         out_be32(&ddr->sdram_clk_cntl,  0x03800000);
92         asm("sync;isync;msync");
93         udelay(500);
94
95         #ifdef CONFIG_DDR_ECC
96           /* Enable ECC checking */
97           out_be32(&ddr->sdram_cfg, CONFIG_SYS_DDR_CONTROL | 0x20000000);
98         #else
99           out_be32(&ddr->sdram_cfg, CONFIG_SYS_DDR_CONTROL);
100         #endif
101
102         return CONFIG_SYS_SDRAM_SIZE * 1024 * 1024;
103 }
104 #endif