[PATCH] m25p80: add support for a callback to platform code on successful device probe
Sudhakar Rajashekhara
sudhakar.raj at ti.com
Tue Aug 10 02:42:58 EDT 2010
On some platforms, MTD device can hold MAC address, calibration
data, serial numbers etc.
On TI's DA850/OMAP-L138/AM18xx EVM, MAC address is stored on
the last sector of the SPI flash, which is exported as an MTD
device.
This patch adds two new members to the 'flash_platform_data'
structure, a function handler which will be called after
add_mtd_device() and an argument to be passed to this function,
for example: offset to read from.
Signed-off-by: Sudhakar Rajashekhara <sudhakar.raj at ti.com>
---
drivers/mtd/devices/m25p80.c | 15 +++++++++++++--
include/linux/spi/flash.h | 2 ++
2 files changed, 15 insertions(+), 2 deletions(-)
diff --git a/drivers/mtd/devices/m25p80.c b/drivers/mtd/devices/m25p80.c
index 81e49a9..b832091 100644
--- a/drivers/mtd/devices/m25p80.c
+++ b/drivers/mtd/devices/m25p80.c
@@ -765,6 +765,7 @@ static int __devinit m25p_probe(struct spi_device *spi)
struct m25p *flash;
struct flash_info *info;
unsigned i;
+ int ret;
/* Platform data helps sort out which chip type we have, as
* well as how this board partitions it. If we don't have
@@ -924,13 +925,23 @@ static int __devinit m25p_probe(struct spi_device *spi)
(long long)(parts[i].size >> 10));
}
flash->partitioned = 1;
- return add_mtd_partitions(&flash->mtd, parts, nr_parts);
+ ret = add_mtd_partitions(&flash->mtd, parts, nr_parts);
+ if (!ret)
+ goto out;
+
+ return ret;
}
} else if (data && data->nr_parts)
dev_warn(&spi->dev, "ignoring %d default partitions on %s\n",
data->nr_parts, data->name);
- return add_mtd_device(&flash->mtd) == 1 ? -ENODEV : 0;
+ ret = add_mtd_device(&flash->mtd);
+
+out:
+ if (data->setup && !ret)
+ (data->setup)(&flash->mtd, (void *)data->context);
+
+ return (ret == 1) ? -ENODEV : 0;
}
diff --git a/include/linux/spi/flash.h b/include/linux/spi/flash.h
index 3f22932..daa4875 100644
--- a/include/linux/spi/flash.h
+++ b/include/linux/spi/flash.h
@@ -24,6 +24,8 @@ struct flash_platform_data {
unsigned int nr_parts;
char *type;
+ void (*setup)(struct mtd_info *, void *context);
+ void *context;
/* we'll likely add more ... use JEDEC IDs, etc */
};
--
1.5.6
More information about the linux-mtd
mailing list