On 27.02.24 11:04, Alexey Romanov wrote:
Bind SPI-NAND driver to MTD block driver.

Signed-off-by: Alexey Romanov <avroma...@salutedevices.com>
---
  drivers/mtd/nand/spi/core.c | 20 ++++++++++++++++++++
  1 file changed, 20 insertions(+)

diff --git a/drivers/mtd/nand/spi/core.c b/drivers/mtd/nand/spi/core.c
index 2a3dbcfcb4..1d9cf66e4a 100644
--- a/drivers/mtd/nand/spi/core.c
+++ b/drivers/mtd/nand/spi/core.c
@@ -36,6 +36,10 @@
  #include <linux/printk.h>
  #endif

+struct spinand_plat {
+       struct mtd_info *mtd;
+};
+
  /* SPI NAND index visible in MTD names */
  static int spi_nand_idx;

@@ -1174,12 +1178,22 @@ static void spinand_cleanup(struct spinand_device 
*spinand)
        kfree(spinand->scratchbuf);
  }

+#if CONFIG_IS_ENABLED(BLK)
+static int spinand_bind(struct udevice *dev)
+{
+       struct spinand_plat *plat = dev_get_plat(dev);
+
+       return mtd_bind(dev, &plat->mtd);
+}
+#endif
+
  static int spinand_probe(struct udevice *dev)
  {
        struct spinand_device *spinand = dev_get_priv(dev);
        struct spi_slave *slave = dev_get_parent_priv(dev);
        struct mtd_info *mtd = dev_get_uclass_priv(dev);
        struct nand_device *nand = spinand_to_nand(spinand);
+       struct spinand_plat *plat = dev_get_plat(dev);
        int ret;

  #ifndef __UBOOT__
@@ -1219,6 +1233,8 @@ static int spinand_probe(struct udevice *dev)
        if (ret)
                goto err_spinand_cleanup;

+       plat->mtd = mtd;
+
        return 0;

  err_spinand_cleanup:
@@ -1288,6 +1304,10 @@ U_BOOT_DRIVER(spinand) = {
        .of_match = spinand_ids,
        .priv_auto      = sizeof(struct spinand_device),
        .probe = spinand_probe,
+#if CONFIG_IS_ENABLED(BLK)


Please, have a look at doc/develop/designprinciples.rst:168:

    * Avoid ``#ifdefs`` where possible

Please, use 'if CONFIG_IS_ENABLED(BLK)' in the bind function.

Best regards

Heinrich

+       .bind = spinand_bind,
+#endif
+       .plat_auto = sizeof(struct spinand_plat),
  };

  void board_nand_init(void)

Reply via email to