]> git.sur5r.net Git - u-boot/commitdiff
83xx, kmeter1: autodetect size of DDR II RAM
authorHeiko Schocher <hs@denx.de>
Tue, 24 Feb 2009 10:30:40 +0000 (11:30 +0100)
committerKim Phillips <kim.phillips@freescale.com>
Fri, 6 Mar 2009 00:21:17 +0000 (18:21 -0600)
it is possible that some board variants have different DDR II
RAM sizes. So we autodetect the size of the assembled RAM.

Signed-off-by: Heiko Schocher <hs@denx.de>
Signed-off-by: Kim Phillips <kim.phillips@freescale.com>
board/keymile/kmeter1/kmeter1.c
include/configs/kmeter1.h

index a3c58aecf1bb8dd23d400349508a812ff2374b4a..4f41f1d76d75512e36b8d6184874089c5335eb8e 100644 (file)
@@ -29,6 +29,8 @@
 
 #include "../common/common.h"
 
+extern void disable_addr_trans (void);
+extern void enable_addr_trans (void);
 const qe_iop_conf_t qe_iop_conf_tab[] = {
        /* port pin dir open_drain assign */
 
@@ -111,16 +113,7 @@ int fixed_sdram(void)
        u32 ddr_size;
        u32 ddr_size_log2;
 
-       msize = CONFIG_SYS_DDR_SIZE;
-       for (ddr_size = msize << 20, ddr_size_log2 = 0;
-            (ddr_size > 1); ddr_size = ddr_size >> 1, ddr_size_log2++) {
-               if (ddr_size & 1)
-                       return -1;
-       }
-
-       im->sysconf.ddrlaw[0].ar =
-           LAWAR_EN | ((ddr_size_log2 - 1) & LAWAR_SIZE);
-
+       im->sysconf.ddrlaw[0].ar = LAWAR_EN | 0x1e;
        im->ddr.csbnds[0].csbnds = CONFIG_SYS_DDR_CS0_BNDS;
        im->ddr.cs_config[0] = CONFIG_SYS_DDR_CS0_CONFIG;
        im->ddr.timing_cfg_0 = CONFIG_SYS_DDR_TIMING_0;
@@ -136,6 +129,21 @@ int fixed_sdram(void)
        udelay (200);
        im->ddr.sdram_cfg |= SDRAM_CFG_MEM_EN;
 
+       msize = CONFIG_SYS_DDR_SIZE << 20;
+       disable_addr_trans ();
+       msize = get_ram_size (CONFIG_SYS_DDR_BASE, msize);
+       enable_addr_trans ();
+       msize /= (1024 * 1024);
+       if (CONFIG_SYS_DDR_SIZE != msize) {
+               for (ddr_size = msize << 20, ddr_size_log2 = 0;
+                    (ddr_size > 1); ddr_size = ddr_size >> 1, ddr_size_log2++)
+                       if (ddr_size & 1)
+                               return -1;
+               im->sysconf.ddrlaw[0].ar =
+                   LAWAR_EN | ((ddr_size_log2 - 1) & LAWAR_SIZE);
+               im->ddr.csbnds[0].csbnds = (((msize / 16) - 1) & 0xff);
+       }
+
        return msize;
 }
 
index a23c9edb5f07b594db9b8345f213951d91598288..ef3faa5ea7c1410c8db538d8a8463b26b121fdc2 100644 (file)
@@ -92,8 +92,8 @@
  * Manually set up DDR parameters
  */
 #define CONFIG_DDR_II
-#define CONFIG_SYS_DDR_SIZE            256 /* MB */
-#define CONFIG_SYS_DDR_CS0_BNDS                0x0000000f
+#define CONFIG_SYS_DDR_SIZE            2048 /* MB */
+#define CONFIG_SYS_DDR_CS0_BNDS                0x0000007f
 #define CONFIG_SYS_DDR_CS0_CONFIG      (CSCONFIG_EN | CSCONFIG_AP | \
                                         CSCONFIG_ROW_BIT_13 | \
                                         CSCONFIG_COL_BIT_10 | CSCONFIG_ODT_WR_ACS)