[U-Boot] [PATCH 2/2] drivers: ubi: Adding UBI loader for SPI flash

tien.fong.chee at intel.com tien.fong.chee at intel.com
Mon Jul 29 07:48:42 UTC 2019


From: Tien Fong Chee <tien.fong.chee at intel.com>

Adding UBI support for SPI flash.

Signed-off-by: Tien Fong Chee <tien.fong.chee at intel.com>
---
 common/spl/spl_ubi.c        | 11 ++++++++++-
 drivers/mtd/spi/sf-uclass.c | 30 ++++++++++++++++++++++++++++++
 include/spi_flash.h         | 10 ++++++++++
 3 files changed, 50 insertions(+), 1 deletion(-)

diff --git a/common/spl/spl_ubi.c b/common/spl/spl_ubi.c
index 0cb5080882..40a449b42b 100644
--- a/common/spl/spl_ubi.c
+++ b/common/spl/spl_ubi.c
@@ -9,6 +9,8 @@
 #include <nand.h>
 #include <onenand_uboot.h>
 #include <ubispl.h>
+#include <spi.h>
+#include <spi_flash.h>
 #include <spl.h>
 
 int spl_ubi_load_image(struct spl_image_info *spl_image,
@@ -33,6 +35,12 @@ int spl_ubi_load_image(struct spl_image_info *spl_image,
 		info.peb_size = CONFIG_SYS_ONENAND_BLOCK_SIZE;
 		break;
 #endif
+#ifdef CONFIG_SPL_SPI_FLASH_SUPPORT
+	case BOOT_DEVICE_SPI:
+		info.read = spi_flash_read_block;
+		info.peb_size = CONFIG_SYS_SPI_BLOCK_SIZE;
+		break;
+#endif
 	default:
 		goto out;
 	}
@@ -82,6 +90,7 @@ out:
 #endif
 	return ret;
 }
-/* Use priorty 0 so that Ubi will override NAND and ONENAND methods */
+/* Use priorty 0 so that Ubi will override SPI, NAND and ONENAND methods */
+SPL_LOAD_IMAGE_METHOD("SPI", 0, BOOT_DEVICE_SPI, spl_ubi_load_image);
 SPL_LOAD_IMAGE_METHOD("NAND", 0, BOOT_DEVICE_NAND, spl_ubi_load_image);
 SPL_LOAD_IMAGE_METHOD("OneNAND", 0, BOOT_DEVICE_ONENAND, spl_ubi_load_image);
diff --git a/drivers/mtd/spi/sf-uclass.c b/drivers/mtd/spi/sf-uclass.c
index 719a2fd23a..45b6dd9e52 100644
--- a/drivers/mtd/spi/sf-uclass.c
+++ b/drivers/mtd/spi/sf-uclass.c
@@ -12,6 +12,36 @@
 
 DECLARE_GLOBAL_DATA_PTR;
 
+/**
+ * spi_flash_read_block - Read data from physical eraseblock into a buffer
+ * @block:	Number of the physical eraseblock
+ * @offset:	Data offset from the start of @peb
+ * @len:	Data size to read
+ * @buf:	Address of the destination buffer
+ * @return 0 if OK, -ve on error
+ */
+int spi_flash_read_block(int block, int offset, int len, void *buf)
+{
+	struct udevice *dev;
+
+	int ret = spi_flash_probe_bus_cs(CONFIG_SF_DEFAULT_BUS,
+					 CONFIG_SF_DEFAULT_CS,
+					 CONFIG_SF_DEFAULT_SPEED,
+					 CONFIG_SF_DEFAULT_MODE, &dev);
+	if (ret) {
+		printf("Failed to initialize SPI flash at ");
+		printf("%u:%u (error %d)\n",CONFIG_SF_DEFAULT_BUS,
+		       CONFIG_SF_DEFAULT_CS, ret);
+		return ret;
+	}
+
+	dev_get_uclass_priv(dev);
+
+	return log_ret(sf_get_ops(dev)->read(dev,
+					      CONFIG_SYS_SPI_BLOCK_SIZE *
+					      block + offset, len, buf));
+}
+
 int spi_flash_read_dm(struct udevice *dev, u32 offset, size_t len, void *buf)
 {
 	return log_ret(sf_get_ops(dev)->read(dev, offset, len, buf));
diff --git a/include/spi_flash.h b/include/spi_flash.h
index 55b4721813..f6eefdc5c8 100644
--- a/include/spi_flash.h
+++ b/include/spi_flash.h
@@ -102,6 +102,16 @@ int spi_flash_erase_dm(struct udevice *dev, u32 offset, size_t len);
  */
 int spl_flash_get_sw_write_prot(struct udevice *dev);
 
+/**
+ * spi_flash_read_block - Read data from physical eraseblock into a buffer
+ * @block:	Number of the physical eraseblock
+ * @offset:	Data offset from the start of @peb
+ * @len:	Data size to read
+ * @buf:	Address of the destination buffer
+ * @return 0 if OK, -ve on error
+ */
+int spi_flash_read_block(int block, int offset, int len, void *dst);
+
 int spi_flash_probe_bus_cs(unsigned int busnum, unsigned int cs,
 			   unsigned int max_hz, unsigned int spi_mode,
 			   struct udevice **devp);
-- 
2.13.0



More information about the U-Boot mailing list