ddr: marvell: a38x: fix memory cs size function
authorMoti Buskila <motib@marvell.com>
Fri, 19 Feb 2021 16:11:22 +0000 (17:11 +0100)
committerStefan Roese <sr@denx.de>
Fri, 26 Feb 2021 09:22:29 +0000 (10:22 +0100)
commit c8b301463d508c807a33f7b7eaea98bbda4aa35e upstream.

The funtion returnd cs size in byte instead of MB, that cause
calculation error since the caller was expected to get u32 and when he
got above 4G it refers it as 0.
The fix was to get the cs memory size from function as in MB and then
multiply it by 1MB.

Signed-off-by: Moti Buskila <motib@marvell.com>
Reviewed-by: Kostya Porotchkin <kostap@marvell.com>
Signed-off-by: Marek BehĂșn <marek.behun@nic.cz>
Tested-by: Chris Packham <chris.packham@alliedtelesis.co.nz>
drivers/ddr/marvell/a38x/mv_ddr_plat.c
drivers/ddr/marvell/a38x/xor.c

index 72f0dfb..0d1df18 100644 (file)
@@ -4,6 +4,7 @@
  */
 
 #include "ddr3_init.h"
+#include "mv_ddr_common.h"
 #include "mv_ddr_training_db.h"
 #include "mv_ddr_regs.h"
 #include "mv_ddr_sys_env_lib.h"
@@ -1016,7 +1017,7 @@ int ddr3_calc_mem_cs_size(u32 cs, uint64_t *cs_size)
                return MV_BAD_VALUE;
        }
 
-       *cs_size = cs_mem_size << 20; /* write cs size in bytes */
+       *cs_size = cs_mem_size;
 
        return MV_OK;
 }
@@ -1025,9 +1026,11 @@ static int ddr3_fast_path_dynamic_cs_size_config(u32 cs_ena)
 {
        u32 reg, cs;
        uint64_t mem_total_size = 0;
+       uint64_t cs_mem_size_mb = 0;
        uint64_t cs_mem_size = 0;
        uint64_t mem_total_size_c, cs_mem_size_c;
 
+
 #ifdef DEVICE_MAX_DRAM_ADDRESS_SIZE
        u32 physical_mem_size;
        u32 max_mem_size = DEVICE_MAX_DRAM_ADDRESS_SIZE;
@@ -1038,8 +1041,9 @@ static int ddr3_fast_path_dynamic_cs_size_config(u32 cs_ena)
        for (cs = 0; cs < MAX_CS_NUM; cs++) {
                if (cs_ena & (1 << cs)) {
                        /* get CS size */
-                       if (ddr3_calc_mem_cs_size(cs, &cs_mem_size) != MV_OK)
+                       if (ddr3_calc_mem_cs_size(cs, &cs_mem_size_mb) != MV_OK)
                                return MV_FAIL;
+                       cs_mem_size = cs_mem_size_mb * _1M;
 
 #ifdef DEVICE_MAX_DRAM_ADDRESS_SIZE
                        /*
@@ -1088,6 +1092,7 @@ static int ddr3_fast_path_dynamic_cs_size_config(u32 cs_ena)
                         */
                        mem_total_size_c = (mem_total_size >> 16) & 0xffffffffffff;
                        cs_mem_size_c = (cs_mem_size >> 16) & 0xffffffffffff;
+
                        /* if the sum less than 2 G - calculate the value */
                        if (mem_total_size_c + cs_mem_size_c < 0x10000)
                                mem_total_size += cs_mem_size;
index 5fb9e21..98fb39e 100644 (file)
@@ -340,7 +340,7 @@ void ddr3_new_tip_ecc_scrub(void)
 {
        u32 cs_c, max_cs;
        u32 cs_ena = 0;
-       uint64_t total_mem_size, cs_mem_size = 0;
+       uint64_t total_mem_size, cs_mem_size_mb = 0, cs_mem_size = 0;
 
        printf("DDR Training Sequence - Start scrubbing\n");
        max_cs = mv_ddr_cs_num_get();
@@ -349,9 +349,9 @@ void ddr3_new_tip_ecc_scrub(void)
 
 #if defined(CONFIG_ARMADA_38X) || defined(CONFIG_ARMADA_39X)
        /* all chip-selects are of same size */
-       ddr3_calc_mem_cs_size(0, &cs_mem_size);
+       ddr3_calc_mem_cs_size(0, &cs_mem_size_mb);
 #endif
-
+       cs_mem_size = cs_mem_size_mb * _1M;
        mv_sys_xor_init(max_cs, cs_ena, cs_mem_size, 0);
        total_mem_size = max_cs * cs_mem_size;
        mv_xor_mem_init(0, 0, total_mem_size, 0xdeadbeef, 0xdeadbeef);