Merge branch '080131_artila' of git://linux-arm.org/u-boot-armdev
[oweals/u-boot.git] / board / netstal / hcu5 / sdram.c
index 40391958d21c51f7318a37c47226cd01e01ebc56..5435de1249c82c56368bca3890906eca85848bad 100644 (file)
@@ -36,7 +36,7 @@
 #include <asm/mmu.h>
 #include <ppc440.h>
 
-void sysLedSet(u32 value);
+void hcu_led_set(u32 value);
 void dcbz_area(u32 start_address, u32 num_bytes);
 void dflush(void);
 
@@ -62,19 +62,21 @@ void dflush(void);
 #define DDR0_22_CTRL_RAW_ECC_ENABLE       0x03000000 /* ECC correcting on */
 #define DDR0_03_CASLAT_DECODE(n)            ((((unsigned long)(n))>>16)&0x7)
 
-#ifdef CFG_ENABLE_SDRAM_CACHE
-#define MY_TLB_WORD2_I_ENABLE  0               /* enable caching on DDR2 */
-#else
-#define MY_TLB_WORD2_I_ENABLE TLB_WORD2_I_ENABLE /* disable caching on DDR2 */
-#endif
+#define ECC_RAM                                0x03267F0B
+#define NO_ECC_RAM                     0x00267F0B
+
+#define HCU_HW_SDRAM_CONFIG_MASK       0x7
+
+#define MY_TLB_WORD2_I_ENABLE TLB_WORD2_I_ENABLE
+       /* disable caching on DDR2 */
 
 void program_tlb(u32 phys_addr, u32 virt_addr, u32 size, u32 tlb_word2_i_value);
 
-#ifdef CONFIG_ADD_RAM_INFO
 void board_add_ram_info(int use_default)
 {
-       PPC440_SYS_INFO board_cfg;
+       PPC4xx_SYS_INFO board_cfg;
        u32 val;
+
        mfsdram(DDR0_22, val);
        val &= DDR0_22_CTRL_RAW_MASK;
        switch (val) {
@@ -99,7 +101,6 @@ void board_add_ram_info(int use_default)
        val = DDR0_03_CASLAT_DECODE(val);
        printf(", CL%d)", val);
 }
-#endif
 
 /*--------------------------------------------------------------------
  * wait_for_dlllock.
@@ -138,7 +139,7 @@ static int wait_for_dlllock(void)
 void sdram_panic(const char *reason)
 {
        printf("\n%s: reason %s",  __FUNCTION__,  reason);
-       sysLedSet(0xff);
+       hcu_led_set(0xff);
        while (1) {
        }
        /* Never return */
@@ -159,44 +160,48 @@ static void blank_string(int size)
 /*---------------------------------------------------------------------------+
  * program_ecc.
  *---------------------------------------------------------------------------*/
-static void program_ecc(unsigned long start_address, unsigned long num_bytes,
-                       unsigned long tlb_word2_i_value)
+static void program_ecc(unsigned long start_address, unsigned long num_bytes)
 {
-       unsigned long current_address= start_address;
-       int loopi = 0;
        u32 val;
-
        char str[] = "ECC generation -";
-       char slash[] = "\\|/-\\|/-";
+#if defined(CONFIG_PRAM)
+       u32 *magic;
+
+       /* Check whether vxWorks is using EDR logging, if yes zero */
+       /* also PostMortem and user reserved memory */
+       magic = (u32 *)in_be32((u32 *)(start_address + num_bytes -
+                                      (CONFIG_PRAM*1024) + sizeof(u32)));
+
+       debug("\n%s:  CONFIG_PRAM %d kB magic 0x%x 0x%p -> 0x%x\n", __FUNCTION__,
+              CONFIG_PRAM,
+              start_address + num_bytes - (CONFIG_PRAM*1024) + sizeof(u32),
+              magic, in_be32(magic));
+       if (in_be32(magic) == 0xbeefbabe)
+               num_bytes -= (CONFIG_PRAM*1024) - PM_RESERVED_MEM;
+#endif
 
        sync();
        eieio();
 
        puts(str);
 
-       if (tlb_word2_i_value == TLB_WORD2_I_ENABLE) {
-               /* ECC bit set method for non-cached memory */
-               /* This takes various seconds */
-               for(current_address = 0; current_address < num_bytes;
-                    current_address += sizeof(u32)) {
-                       *(u32 *)current_address = 0;
-                       if ((current_address % (2 << 20)) == 0) {
-                               putc('\b');
-                               putc(slash[loopi++ % 8]);
-                       }
-               }
-       } else {
-               /* ECC bit set method for cached memory */
-               /* Fast method, no noticeable delay */
-               dcbz_area(start_address, num_bytes);
-               dflush();
-       }
+       /* ECC bit set method for cached memory */
+       /* Fast method, no noticeable delay */
+       dcbz_area(start_address, num_bytes);
+       dflush();
        blank_string(strlen(str));
 
        /* Clear error status */
        mfsdram(DDR0_00, val);
        mtsdram(DDR0_00, val | DDR0_00_INT_ACK_ALL);
 
+       /*
+        * Clear possible ECC errors
+        * If not done, then we could get an interrupt later on when
+        * exceptions are enabled.
+        */
+       mtspr(mcsr, mfspr(mcsr));
+
        /* Set 'int_mask' parameter to functionnal value */
        mfsdram(DDR0_01, val);
        mtsdram(DDR0_01, ((val &~ DDR0_01_INT_MASK_MASK) |
@@ -204,9 +209,9 @@ static void program_ecc(unsigned long start_address, unsigned long num_bytes,
 
        return;
 }
-
 #endif
 
+
 /***********************************************************************
  *
  * initdram -- 440EPx's DDR controller is a DENALI Core
@@ -214,9 +219,6 @@ static void program_ecc(unsigned long start_address, unsigned long num_bytes,
  ************************************************************************/
 long int initdram (int board_type)
 {
-#define        HCU_HW_SDRAM_CONFIG_MASK 0x7
-#define INVALID_HW_CONFIG   "Invalid HW-Config"
-       u16 *hwVersReg = (u16 *) HCU_HW_VERSION_REGISTER;
        unsigned int dram_size = 0;
 
        mtsdram(DDR0_02, 0x00000000);
@@ -227,25 +229,23 @@ long int initdram (int board_type)
        mtsdram(DDR0_03, 0x02030602);
        mtsdram(DDR0_04, 0x0A020200);
        mtsdram(DDR0_05, 0x02020307);
-       switch (*hwVersReg & HCU_HW_SDRAM_CONFIG_MASK) {
-       case 0:
-               dram_size = 128 * 1024 * 1024 ;
-               mtsdram(DDR0_06, 0x0102C80D);  /* 128MB RAM */
-               mtsdram(DDR0_11, 0x000FC800);  /* 128MB RAM */
-               mtsdram(DDR0_43, 0x030A0300);  /* 128MB RAM */
-               break;
+       switch (in_be16((u16 *)HCU_HW_VERSION_REGISTER) & HCU_HW_SDRAM_CONFIG_MASK) {
        case 1:
                dram_size = 256 * 1024 * 1024 ;
                mtsdram(DDR0_06, 0x0102C812);  /* 256MB RAM */
                mtsdram(DDR0_11, 0x0014C800);  /* 256MB RAM */
                mtsdram(DDR0_43, 0x030A0200);  /* 256MB RAM */
                break;
+       case 0:
        default:
-               sdram_panic(INVALID_HW_CONFIG);
+               dram_size = 128 * 1024 * 1024 ;
+               mtsdram(DDR0_06, 0x0102C80D);  /* 128MB RAM */
+               mtsdram(DDR0_11, 0x000FC800);  /* 128MB RAM */
+               mtsdram(DDR0_43, 0x030A0300);  /* 128MB RAM */
                break;
        }
-       dram_size -= 16 * 1024 * 1024;
        mtsdram(DDR0_07, 0x00090100);
+
        /*
         * TCPD=200 cycles of clock input is required to lock the DLL.
         * CKE must be HIGH the entire time.mtsdram(DDR0_08, 0x02C80001);
@@ -260,8 +260,6 @@ long int initdram (int board_type)
        mtsdram(DDR0_19, 0x1D1D1D1D);
        mtsdram(DDR0_20, 0x0B0B0B0B);
        mtsdram(DDR0_21, 0x0B0B0B0B);
-       #define ECC_RAM  0x03267F0B
-       #define NO_ECC_RAM  0x00267F0B
 #ifdef CONFIG_DDR_ECC
        mtsdram(DDR0_22, ECC_RAM);
 #else
@@ -283,7 +281,8 @@ long int initdram (int board_type)
        /*
         * Program tlb entries for this size (dynamic)
         */
-       program_tlb(0, 0, dram_size, MY_TLB_WORD2_I_ENABLE);
+       remove_tlb(CFG_SDRAM_BASE, 256 << 20);
+       program_tlb(0, 0, dram_size, TLB_WORD2_W_ENABLE | TLB_WORD2_I_ENABLE);
 
        /*
         * Setup 2nd TLB with same physical address but different virtual
@@ -295,7 +294,7 @@ long int initdram (int board_type)
        /*
         * If ECC is enabled, initialize the parity bits.
         */
-       program_ecc(CFG_DDR_CACHED_ADDR, dram_size, 0);
+       program_ecc(CFG_DDR_CACHED_ADDR, dram_size);
 #endif
 
        return (dram_size);