mpc512x: Streamlined fixed_sdram() init sequence.
authorMartha M Stan <mmarx@silicontkx.com>
Mon, 21 Sep 2009 18:07:14 +0000 (14:07 -0400)
committerWolfgang Denk <wd@denx.de>
Thu, 24 Sep 2009 22:45:30 +0000 (00:45 +0200)
Signed-off-by: Martha M Stan <mmarx@silicontkx.com>
Minor cleanup:

Re-ordered default_mddrc_config[] to have matching indices.

This allows to use the same index "N" for source and target fields;
before, we had code like this

out_be32(&im->mddrc.ddr_time_config2, mddrc_config[3]);

which always looked like a copy & paste error because 2 != 3.

Also, use NULL when meaning a null pointer.

Signed-off-by: Wolfgang Denk <wd@denx.de>
board/davedenx/aria/aria.c
board/esd/mecp5123/mecp5123.c
board/freescale/mpc5121ads/mpc5121ads.c
cpu/mpc512x/fixed_sdram.c
include/asm-ppc/immap_512x.h
include/asm-ppc/mpc512x.h
include/configs/aria.h
include/configs/mecp5123.h
include/configs/mpc5121ads.h

index 2064aa2c6c19bf35d93689c5526af71da1f9f858..cc69c9d38e0e172ff63a76e19fb5f6faf0859849 100644 (file)
@@ -101,7 +101,7 @@ int board_early_init_f(void)
 
 phys_size_t initdram (int board_type)
 {
-       return fixed_sdram();
+       return fixed_sdram(NULL, NULL, 0);
 }
 
 int misc_init_r(void)
index f591e326210adc9a48dc3925ca562426b01fb102..51393584438ad344aa110e7af890637b01d1c3ae 100644 (file)
@@ -135,7 +135,7 @@ int board_early_init_f(void)
 
 phys_size_t initdram(int board_type)
 {
-       return get_ram_size(0, fixed_sdram());
+       return get_ram_size(0, fixed_sdram(NULL, NULL, 0));
 }
 
 int misc_init_r(void)
index a0d7a82e4bb5ddbd5cc9c1303a7bb51f64d70fae..8defb001a38f40f710af33f73013f39af9c72667 100644 (file)
@@ -137,7 +137,7 @@ phys_size_t initdram(int board_type)
 {
        u32 msize = 0;
 
-       msize = fixed_sdram();
+       msize = fixed_sdram(NULL, NULL, 0);
 
        return msize;
 }
index d906903d28d104d25265f2ac752d89d5bfdcc12c..673d61ee1005af04b84b7e846fd81f84d91495d9 100644 (file)
 #include <asm/io.h>
 #include <asm/mpc512x.h>
 
+/*
+ * MDDRC Config Runtime Settings in order of the 4 MDDRC cfg registers
+ */
+u32 default_mddrc_config[4] = {
+       CONFIG_SYS_MDDRC_TIME_CFG0,     /* time_config0 */
+       CONFIG_SYS_MDDRC_TIME_CFG1,     /* time_config1 */
+       CONFIG_SYS_MDDRC_TIME_CFG2,     /* time_config2 */
+       CONFIG_SYS_MDDRC_SYS_CFG,       /* sys_config   */
+};
+
+u32 default_init_seq[] = {
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_PCHG_ALL,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_RFSH,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_RFSH,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_MICRON_INIT_DEV_OP,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_EM2,
+       CONFIG_SYS_DDRCMD_NOP,
+       CONFIG_SYS_DDRCMD_PCHG_ALL,
+       CONFIG_SYS_DDRCMD_EM2,
+       CONFIG_SYS_DDRCMD_EM3,
+       CONFIG_SYS_DDRCMD_EN_DLL,
+       CONFIG_SYS_MICRON_INIT_DEV_OP,
+       CONFIG_SYS_DDRCMD_PCHG_ALL,
+       CONFIG_SYS_DDRCMD_RFSH,
+       CONFIG_SYS_MICRON_INIT_DEV_OP,
+       CONFIG_SYS_DDRCMD_OCD_DEFAULT,
+       CONFIG_SYS_DDRCMD_PCHG_ALL,
+       CONFIG_SYS_DDRCMD_NOP
+};
+
 /*
  * fixed sdram init:
  * The board doesn't use memory modules that have serial presence
  * detect or similar mechanism for discovery of the DRAM settings
  */
-long int fixed_sdram(void)
+long int fixed_sdram(u32 *mddrc_config, u32 *dram_init_seq, int seq_sz)
 {
        volatile immap_t *im = (immap_t *)CONFIG_SYS_IMMR;
        u32 msize = CONFIG_SYS_DDR_SIZE * 1024 * 1024;
        u32 msize_log2 = __ilog2(msize);
        u32 i;
 
+       /* take default settings and init sequence if necessary */
+       if (mddrc_config == NULL)
+               mddrc_config = default_mddrc_config;
+       if (dram_init_seq == NULL) {
+               dram_init_seq = default_init_seq;
+               seq_sz = sizeof(default_init_seq)/sizeof(u32);
+       }
+
        /* Initialize IO Control */
        out_be32(&im->io_ctrl.io_control_mem, IOCTRL_MUX_DDR);
 
@@ -45,8 +97,8 @@ long int fixed_sdram(void)
        out_be32(&im->sysconf.ddrlaw.ar, msize_log2 - 1);
        sync_law(&im->sysconf.ddrlaw.ar);
 
-       /* Enable DDR */
-       out_be32(&im->mddrc.ddr_sys_config, CONFIG_SYS_MDDRC_SYS_CFG_EN);
+       /* DDR Enable */
+       out_be32(&im->mddrc.ddr_sys_config, MDDRC_SYS_CFG_EN);
 
        /* Initialize DDR Priority Manager */
        out_be32(&im->mddrc.prioman_config1, CONFIG_SYS_MDDRCGRP_PM_CFG1);
@@ -73,41 +125,23 @@ long int fixed_sdram(void)
        out_be32(&im->mddrc.lut_table4_alternate_upper, CONFIG_SYS_MDDRCGRP_LUT4_AU);
        out_be32(&im->mddrc.lut_table4_alternate_lower, CONFIG_SYS_MDDRCGRP_LUT4_AL);
 
-       /* Initialize MDDRC */
-       out_be32(&im->mddrc.ddr_sys_config, CONFIG_SYS_MDDRC_SYS_CFG);
-       out_be32(&im->mddrc.ddr_time_config0, CONFIG_SYS_MDDRC_TIME_CFG0);
-       out_be32(&im->mddrc.ddr_time_config1, CONFIG_SYS_MDDRC_TIME_CFG1);
-       out_be32(&im->mddrc.ddr_time_config2, CONFIG_SYS_MDDRC_TIME_CFG2);
-
-       /* Initialize DDR */
-       for (i = 0; i < 10; i++)
-               out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
+       /*
+        * Initialize MDDRC
+        *  put MDDRC in CMD mode and
+        *  set the max time between refreshes to 0 during init process
+        */
+       out_be32(&im->mddrc.ddr_sys_config, mddrc_config[3] | MDDRC_SYS_CFG_CMD_MASK);
+       out_be32(&im->mddrc.ddr_time_config0, mddrc_config[0] & MDDRC_REFRESH_ZERO_MASK);
+       out_be32(&im->mddrc.ddr_time_config1, mddrc_config[1]);
+       out_be32(&im->mddrc.ddr_time_config2, mddrc_config[2]);
 
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_PCHG_ALL);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_RFSH);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_RFSH);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_INIT_DEV_OP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_EM2);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_PCHG_ALL);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_EM2);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_EM3);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_EN_DLL);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_INIT_DEV_OP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_PCHG_ALL);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_RFSH);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_INIT_DEV_OP);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_OCD_DEFAULT);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_PCHG_ALL);
-       out_be32(&im->mddrc.ddr_command, CONFIG_SYS_MICRON_NOP);
+       /* Initialize DDR with either default or supplied init sequence */
+       for (i = 0; i < seq_sz; i++)
+               out_be32(&im->mddrc.ddr_command, dram_init_seq[i]);
 
        /* Start MDDRC */
-       out_be32(&im->mddrc.ddr_time_config0, CONFIG_SYS_MDDRC_TIME_CFG0_RUN);
-       out_be32(&im->mddrc.ddr_sys_config, CONFIG_SYS_MDDRC_SYS_CFG_RUN);
+       out_be32(&im->mddrc.ddr_time_config0, mddrc_config[0]);
+       out_be32(&im->mddrc.ddr_sys_config, mddrc_config[3]);
 
        return msize;
 }
index 24e6c6934eeed174d799053b1d5229099fc412c1..79cdd80298f9fb1de907905103316ac1d9ff1509 100644 (file)
@@ -341,6 +341,10 @@ typedef struct ddr512x {
        u32 res2[0x3AD];
 } ddr512x_t;
 
+/* MDDRC SYS CFG and Timing CFG0 Registers */
+#define MDDRC_SYS_CFG_EN       0xF0000000
+#define MDDRC_SYS_CFG_CMD_MASK 0x10000000
+#define MDDRC_REFRESH_ZERO_MASK        0x0000FFFF
 
 /*
  * DMA/Messaging Unit
index 20456f52f7d2638775170faf8ec3fd618a85daec..8ef0d9ca6ddbf4e77d68ccde6357ed6f3ff8b4f4 100644 (file)
@@ -50,7 +50,7 @@ static inline void sync_law(volatile void *addr)
 /*
  * Prototypes
  */
-extern long int fixed_sdram(void);
+extern long int fixed_sdram(u32 *mddrc_config, u32 *dram_init_seq, int seq_sz);
 extern int mpc5121_diu_init(void);
 extern void ide_set_reset(int idereset);
 
index 4211113d9e136494c7afdb0eb3e10f914ed71560..2938eac396dbc2be14f8786448004dec9ba8221f 100644 (file)
 #define CONFIG_SYS_MDDRC_SYS_CFG     ( (1 << 31) |     /* RST_B */ \
                                        (1 << 30) |     /* CKE */ \
                                        (1 << 29) |     /* CLK_ON */ \
-                                       (1 << 28) |     /* CMD_MODE */ \
+                                       (0 << 28) |     /* CMD_MODE */ \
                                        (4 << 25) |     /* DRAM_ROW_SELECT */ \
                                        (3 << 21) |     /* DRAM_BANK_SELECT */ \
                                        (0 << 18) |     /* SELF_REF_EN */ \
                                        (0 <<  0)       /* FIFO_UV_EN */ \
                                     )
 
-#define CONFIG_SYS_MDDRC_SYS_CFG_RUN   (CONFIG_SYS_MDDRC_SYS_CFG & ~(1 << 28))
+#define CONFIG_SYS_MDDRC_TIME_CFG0     0x030C3D2E
 #define CONFIG_SYS_MDDRC_TIME_CFG1     0x55D81189
 #define CONFIG_SYS_MDDRC_TIME_CFG2     0x34790863
 
-#define CONFIG_SYS_MDDRC_SYS_CFG_EN    0xF0000000
-#define CONFIG_SYS_MDDRC_TIME_CFG0     0x00003D2E
-#define CONFIG_SYS_MDDRC_TIME_CFG0_RUN 0x030C3D2E
-
-#define CONFIG_SYS_MICRON_NOP          0x01380000
-#define CONFIG_SYS_MICRON_PCHG_ALL     0x01100400
+#define CONFIG_SYS_DDRCMD_NOP          0x01380000
+#define CONFIG_SYS_DDRCMD_PCHG_ALL     0x01100400
 #define CONFIG_SYS_MICRON_EMR       (  (1 << 24) |     /* CMD_REQ */ \
                                        (0 << 22) |     /* DRAM_CS */ \
                                        (0 << 21) |     /* DRAM_RAS */ \
                                     )
 #define CONFIG_SYS_MICRON_EMR2         0x01020000
 #define CONFIG_SYS_MICRON_EMR3         0x01030000
-#define CONFIG_SYS_MICRON_RFSH         0x01080000
+#define CONFIG_SYS_DDRCMD_RFSH         0x01080000
 #define CONFIG_SYS_MICRON_INIT_DEV_OP  0x01000432
 #define CONFIG_SYS_MICRON_EMR_OCD    ( (1 << 24) |     /* CMD_REQ */ \
                                        (0 << 22) |     /* DRAM_CS */ \
  * Backward compatible definitions,
  * so we do not have to change cpu/mpc512x/fixed_sdram.c
  */
-#define        CONFIG_SYS_MICRON_EM2           (CONFIG_SYS_MICRON_EMR2)
-#define CONFIG_SYS_MICRON_EM3          (CONFIG_SYS_MICRON_EMR3)
-#define CONFIG_SYS_MICRON_EN_DLL       (CONFIG_SYS_MICRON_EMR)
-#define CONFIG_SYS_MICRON_OCD_DEFAULT  (CONFIG_SYS_MICRON_EMR_OCD)
+#define        CONFIG_SYS_DDRCMD_EM2           (CONFIG_SYS_MICRON_EMR2)
+#define CONFIG_SYS_DDRCMD_EM3          (CONFIG_SYS_MICRON_EMR3)
+#define CONFIG_SYS_DDRCMD_EN_DLL       (CONFIG_SYS_MICRON_EMR)
+#define CONFIG_SYS_DDRCMD_OCD_DEFAULT  (CONFIG_SYS_MICRON_EMR_OCD)
 
 /* DDR Priority Manager Configuration */
 #define CONFIG_SYS_MDDRCGRP_PM_CFG1    0x00077777
index 1ecae005ce2c3efe42340529081765900b0215e1..e194c8f7bbed64eaef0204657262f8740e523233 100644 (file)
  *     [09:05] DRAM tRP:
  *     [04:00] DRAM tRPA
  */
-#define CONFIG_SYS_MDDRC_SYS_CFG        0xFA804A00
-#define CONFIG_SYS_MDDRC_SYS_CFG_RUN    0xEA804A00
+#define CONFIG_SYS_MDDRC_SYS_CFG        0xEA804A00
+#define CONFIG_SYS_MDDRC_TIME_CFG0      0x06183D2E
 #define CONFIG_SYS_MDDRC_TIME_CFG1      0x68EC1168
 #define CONFIG_SYS_MDDRC_TIME_CFG2      0x34310864
-#define CONFIG_SYS_MDDRC_SYS_CFG_EN    0xF0000000
-#define CONFIG_SYS_MDDRC_TIME_CFG0     0x00003D2E
-#define CONFIG_SYS_MDDRC_TIME_CFG0_RUN 0x06183D2E
-
-#define CONFIG_SYS_MICRON_NOP          0x01380000
-#define CONFIG_SYS_MICRON_PCHG_ALL     0x01100400
-#define CONFIG_SYS_MICRON_EM2          0x01020000
-#define CONFIG_SYS_MICRON_EM3          0x01030000
-#define CONFIG_SYS_MICRON_EN_DLL       0x01010000
-#define CONFIG_SYS_MICRON_RFSH         0x01080000
+
+#define CONFIG_SYS_DDRCMD_NOP          0x01380000
+#define CONFIG_SYS_DDRCMD_PCHG_ALL     0x01100400
+#define CONFIG_SYS_DDRCMD_EM2          0x01020000
+#define CONFIG_SYS_DDRCMD_EM3          0x01030000
+#define CONFIG_SYS_DDRCMD_EN_DLL       0x01010000
+#define CONFIG_SYS_DDRCMD_RFSH         0x01080000
 #define CONFIG_SYS_MICRON_INIT_DEV_OP  0x01000432
-#define CONFIG_SYS_MICRON_OCD_DEFAULT  0x01010780
+#define CONFIG_SYS_DDRCMD_OCD_DEFAULT  0x01010780
 
 /* DDR Priority Manager Configuration */
 #define CONFIG_SYS_MDDRCGRP_PM_CFG1    0x00077777
index 76f174db3fa57849adebf7dea7c287555c13448a..0c871c919519a76349c486abc4b1f52907294077 100644 (file)
  *     [04:00] DRAM tRPA
  */
 #ifdef CONFIG_MPC5121ADS_REV2
-#define CONFIG_SYS_MDDRC_SYS_CFG       0xF8604A00
-#define CONFIG_SYS_MDDRC_SYS_CFG_RUN   0xE8604A00
+#define CONFIG_SYS_MDDRC_SYS_CFG       0xE8604A00
 #define CONFIG_SYS_MDDRC_TIME_CFG1     0x54EC1168
 #define CONFIG_SYS_MDDRC_TIME_CFG2     0x35210864
 #else
-#define CONFIG_SYS_MDDRC_SYS_CFG        0xFA804A00
-#define CONFIG_SYS_MDDRC_SYS_CFG_RUN    0xEA804A00
-#define CONFIG_SYS_MDDRC_TIME_CFG1      0x68EC1168
-#define CONFIG_SYS_MDDRC_TIME_CFG2      0x34310864
+#define CONFIG_SYS_MDDRC_SYS_CFG       0xEA804A00
+#define CONFIG_SYS_MDDRC_TIME_CFG1     0x68EC1168
+#define CONFIG_SYS_MDDRC_TIME_CFG2     0x34310864
 #endif
-#define CONFIG_SYS_MDDRC_SYS_CFG_EN    0xF0000000
-#define CONFIG_SYS_MDDRC_TIME_CFG0     0x00003D2E
-#define CONFIG_SYS_MDDRC_TIME_CFG0_RUN 0x06183D2E
-
-#define CONFIG_SYS_MICRON_NOP          0x01380000
-#define CONFIG_SYS_MICRON_PCHG_ALL     0x01100400
-#define CONFIG_SYS_MICRON_EM2          0x01020000
-#define CONFIG_SYS_MICRON_EM3          0x01030000
-#define CONFIG_SYS_MICRON_EN_DLL       0x01010000
-#define CONFIG_SYS_MICRON_RFSH         0x01080000
+#define CONFIG_SYS_MDDRC_TIME_CFG0     0x06183D2E
+
+#define CONFIG_SYS_DDRCMD_NOP          0x01380000
+#define CONFIG_SYS_DDRCMD_PCHG_ALL     0x01100400
+#define CONFIG_SYS_DDRCMD_EM2          0x01020000
+#define CONFIG_SYS_DDRCMD_EM3          0x01030000
+#define CONFIG_SYS_DDRCMD_EN_DLL       0x01010000
+#define CONFIG_SYS_DDRCMD_RFSH         0x01080000
 #define CONFIG_SYS_MICRON_INIT_DEV_OP  0x01000432
-#define CONFIG_SYS_MICRON_OCD_DEFAULT  0x01010780
+#define CONFIG_SYS_DDRCMD_OCD_DEFAULT  0x01010780
 
 /* DDR Priority Manager Configuration */
 #define CONFIG_SYS_MDDRCGRP_PM_CFG1    0x00077777