Signed-off-by: Mingkai Hu <mingkai...@freescale.com>
---

v2:
 - Move the flash partition function from of_spi.c to MTD driver

 drivers/mtd/devices/m25p80.c |   29 +++++++++++++++++++++++++++++
 1 files changed, 29 insertions(+), 0 deletions(-)

diff --git a/drivers/mtd/devices/m25p80.c b/drivers/mtd/devices/m25p80.c
index 81e49a9..5f00075 100644
--- a/drivers/mtd/devices/m25p80.c
+++ b/drivers/mtd/devices/m25p80.c
@@ -752,6 +752,31 @@ static const struct spi_device_id *__devinit 
jedec_probe(struct spi_device *spi)
        return NULL;
 }
 
+/*
+ * parse_flash_partition - Parse the flash partition on the SPI bus
+ * @spi: Pointer to spi_device device
+ */
+void parse_flash_partition(struct spi_device *spi)
+{
+       struct mtd_partition *parts;
+       struct flash_platform_data *pdata;
+       int nr_parts = 0;
+       struct device_node *np = spi->dev.of_node;
+
+       nr_parts = of_mtd_parse_partitions(&spi->dev, np, &parts);
+       if (!nr_parts)
+               return;
+
+       pdata = kzalloc(sizeof(*pdata), GFP_KERNEL);
+       if (!pdata)
+               return;
+
+       pdata->parts = parts;
+       pdata->nr_parts = nr_parts;
+       spi->dev.platform_data = pdata;
+
+       return;
+}
 
 /*
  * board specific setup should have ensured the SPI clock used here
@@ -771,6 +796,10 @@ static int __devinit m25p_probe(struct spi_device *spi)
         * a chip ID, try the JEDEC id commands; they'll work for most
         * newer chips, even if we don't recognize the particular chip.
         */
+
+       /* Parse the flash partition */
+       parse_flash_partition(spi);
+
        data = spi->dev.platform_data;
        if (data && data->type) {
                const struct spi_device_id *plat_id;
-- 
1.6.4


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to