x86: Adjust mrccache_get_region() to support get_mmap()
authorSimon Glass <sjg@chromium.org>
Sat, 7 Dec 2019 04:42:04 +0000 (21:42 -0700)
committerBin Meng <bmeng.cn@gmail.com>
Sun, 15 Dec 2019 03:44:13 +0000 (11:44 +0800)
It is now possible to obtain the memory map for a SPI controllers instead
of having it hard-coded in the device tree. Update the code to support
this.

Signed-off-by: Simon Glass <sjg@chromium.org>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
arch/x86/lib/mrccache.c

index 50c72bf962fe40355afc848dbd32176ced2f88d5..7136166be60966c839135c11ab0fa774ade3f7e0 100644 (file)
@@ -210,6 +210,9 @@ int mrccache_get_region(struct udevice **devp, struct mrc_region *entry)
 {
        struct udevice *dev;
        ofnode mrc_node;
+       ulong map_base;
+       uint map_size;
+       uint offset;
        u32 reg[2];
        int ret;
 
@@ -221,10 +224,15 @@ int mrccache_get_region(struct udevice **devp, struct mrc_region *entry)
        ret = uclass_find_first_device(UCLASS_SPI_FLASH, &dev);
        if (ret)
                return log_msg_ret("Cannot find SPI flash\n", ret);
-       ret = dev_read_u32_array(dev, "memory-map", reg, 2);
-       if (ret)
-               return log_msg_ret("Cannot find memory map\n", ret);
-       entry->base = reg[0];
+       ret = dm_spi_get_mmap(dev, &map_base, &map_size, &offset);
+       if (!ret) {
+               entry->base = map_base;
+       } else {
+               ret = dev_read_u32_array(dev, "memory-map", reg, 2);
+               if (ret)
+                       return log_msg_ret("Cannot find memory map\n", ret);
+               entry->base = reg[0];
+       }
 
        /* Find the place where we put the MRC cache */
        mrc_node = dev_read_subnode(dev, "rw-mrc-cache");
@@ -239,6 +247,8 @@ int mrccache_get_region(struct udevice **devp, struct mrc_region *entry)
 
        if (devp)
                *devp = dev;
+       debug("MRC cache in '%s', offset %x, len %x, base %x\n",
+             dev->name, entry->offset, entry->length, entry->base);
 
        return 0;
 }