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 72f0dfbbbb1d8f8effc46a3392f895a049705154..0d1df189e8202871c83521c32c7b3eba4af934a3 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 5fb9e216d38bcdb04a2e34fbbafd071e10f7b2b6..98fb39eaf0fab0bbc00a2b37991d1738bc5828d8 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);