[PATCH v2 2/2] ram: sifive: Avoid using hardcoded ram base and size
Pragnesh Patel
pragnesh.patel at sifive.com
Mon Jul 20 11:28:56 CEST 2020
Hi Bin,
>-----Original Message-----
>From: Bin Meng <bmeng.cn at gmail.com>
>Sent: 20 July 2020 11:37
>To: Rick Chen <rick at andestech.com>; Pragnesh Patel
><pragnesh.patel at sifive.com>; Sagar Kadam <sagar.kadam at sifive.com>; U-
>Boot Mailing List <u-boot at lists.denx.de>
>Cc: Bin Meng <bin.meng at windriver.com>
>Subject: [PATCH v2 2/2] ram: sifive: Avoid using hardcoded ram base and size
>
>[External Email] Do not click links or attachments unless you recognize the
>sender and know the content is safe
>
>From: Bin Meng <bin.meng at windriver.com>
>
>At present the SiFive FU540 RAM driver uses hard-coded memory base
>address and size to initialize the DDR controller. This may not be true when
>this driver is used on another board based on FU540.
>
>Update the driver to read the memory information from DT and use that
>during the initialization.
>
>Signed-off-by: Bin Meng <bin.meng at windriver.com>
>---
>
>Changes in v2:
>- Change to use fdtdec_setup_mem_size_base() API
>- Drop the 2 patches that added a new API in fdtdec
>
> drivers/ram/sifive/fu540_ddr.c | 30 +++++++++++++++---------------
> 1 file changed, 15 insertions(+), 15 deletions(-)
>
>diff --git a/drivers/ram/sifive/fu540_ddr.c b/drivers/ram/sifive/fu540_ddr.c
>index f8f8ca9..2eef1e7 100644
>--- a/drivers/ram/sifive/fu540_ddr.c
>+++ b/drivers/ram/sifive/fu540_ddr.c
>@@ -8,6 +8,7 @@
>
> #include <common.h>
> #include <dm.h>
>+#include <fdtdec.h>
> #include <init.h>
> #include <ram.h>
> #include <regmap.h>
>@@ -39,9 +40,6 @@
> #define DENALI_PHY_1152 1152
> #define DENALI_PHY_1214 1214
>
>-#define PAYLOAD_DEST 0x80000000
>-#define DDR_MEM_SIZE (8UL * 1024UL * 1024UL * 1024UL)
>-
> #define DRAM_CLASS_OFFSET 8
> #define DRAM_CLASS_DDR4 0xA
> #define OPTIMAL_RMODW_EN_OFFSET 0
>@@ -65,6 +63,8 @@
> #define PHY_RX_CAL_DQ0_0_OFFSET 0
> #define PHY_RX_CAL_DQ1_0_OFFSET 16
>
>+DECLARE_GLOBAL_DATA_PTR;
>+
> struct fu540_ddrctl {
> volatile u32 denali_ctl[265];
> };
>@@ -235,8 +235,8 @@ static int fu540_ddr_setup(struct udevice *dev)
> struct fu540_ddr_params *params = &plat->ddr_params;
> volatile u32 *denali_ctl = priv->ctl->denali_ctl;
> volatile u32 *denali_phy = priv->phy->denali_phy;
>- const u64 ddr_size = DDR_MEM_SIZE;
>- const u64 ddr_end = PAYLOAD_DEST + ddr_size;
>+ const u64 ddr_size = priv->info.size;
>+ const u64 ddr_end = priv->info.base + ddr_size;
> int ret, i;
> u32 physet;
>
>@@ -302,7 +302,7 @@ static int fu540_ddr_setup(struct udevice *dev)
> | (1 << MULTIPLE_OUT_OF_RANGE_OFFSET));
>
> /* set up range protection */
>- fu540_ddr_setup_range_protection(denali_ctl, DDR_MEM_SIZE);
>+ fu540_ddr_setup_range_protection(denali_ctl, priv->info.size);
>
> /* Mask off port command error interrupt DENALI_CTL_136 */
> setbits_le32(DENALI_CTL_136 + denali_ctl, @@ -314,14 +314,14 @@ static
>int fu540_ddr_setup(struct udevice *dev)
>
> /* check size */
> priv->info.size = get_ram_size((long *)priv->info.base,
>- DDR_MEM_SIZE);
>+ ddr_size);
>
> debug("%s : %lx\n", __func__, priv->info.size);
>
> /* check memory access for all memory */
>- if (priv->info.size != DDR_MEM_SIZE) {
>+ if (priv->info.size != ddr_size) {
> printf("DDR invalid size : 0x%lx, expected 0x%lx\n",
>- priv->info.size, DDR_MEM_SIZE);
>+ priv->info.size, (uintptr_t)ddr_size);
> return -EINVAL;
> }
>
>@@ -333,6 +333,11 @@ static int fu540_ddr_probe(struct udevice *dev) {
> struct fu540_ddr_info *priv = dev_get_priv(dev);
>
>+ /* Read memory base and size from DT */
>+ fdtdec_setup_mem_size_base();
>+ priv->info.base = gd->ram_base;
>+ priv->info.size = gd->ram_size;
>+
> #if defined(CONFIG_SPL_BUILD)
> struct regmap *map;
> int ret;
>@@ -368,14 +373,9 @@ static int fu540_ddr_probe(struct udevice *dev)
> priv->phy = regmap_get_range(map, 1);
> priv->physical_filter_ctrl = regmap_get_range(map, 2);
>
>- priv->info.base = CONFIG_SYS_SDRAM_BASE;
>-
>- priv->info.size = 0;
> return fu540_ddr_setup(dev);
>-#else
>- priv->info.base = CONFIG_SYS_SDRAM_BASE;
>- priv->info.size = DDR_MEM_SIZE;
This "else" part also need to be updated rather than removing it because it used by
fu540_ddr_get_info() function in case of U-Boot.
> #endif
>+
> return 0;
> }
>
>--
>2.7.4
More information about the U-Boot
mailing list