Comments
Patch
@@ -456,6 +456,46 @@ int mtd_device_register(struct mtd_info *master,
}
EXPORT_SYMBOL_GPL(mtd_device_register);
+int mtd_device_parse_register(struct mtd_info *mtd,
+ const char **part_probe_types,
+ unsigned long origin,
+ const struct mtd_partition *defparts,
+ int defnr_parts)
+{
+ int err;
+ struct mtd_partition *parts;
+
+ err = parse_mtd_partitions(mtd, part_probe_types, &parts, origin);
+ if (err <= 0 && defnr_parts) {
+ unsigned long size = sizeof(*parts) * defnr_parts;
+ err = defnr_parts;
+ parts = kzalloc(size, GFP_KERNEL);
+ memcpy(parts, defparts, size);
+ }
+
+#ifdef CONFIG_OF
+ if (mtd->node)
+ of_node_get(mtd->node);
+#endif
+
+ if (err > 0) {
+ err = add_mtd_partitions(mtd, parts, err);
+ kfree(parts);
+ } else {
+ err = add_mtd_device(mtd);
+ if (err == 1)
+ err = -ENODEV;
+ }
+
+#ifdef CONFIG_OF
+ if (err < 0 && mtd->node)
+ of_node_put(mtd->node);
+#endif
+
+ return err;
+}
+EXPORT_SYMBOL_GPL(mtd_device_parse_register);
+
/**
* mtd_device_unregister - unregister an existing MTD device.
*
@@ -330,6 +330,11 @@ struct mtd_partition;
extern int mtd_device_register(struct mtd_info *master,
const struct mtd_partition *parts,
int nr_parts);
+extern int mtd_device_parse_register(struct mtd_info *mtd,
+ const char **part_probe_types,
+ unsigned long origin,
+ const struct mtd_partition *defparts,
+ int defnr_parts);
extern int mtd_device_unregister(struct mtd_info *master);
extern struct mtd_info *get_mtd_device(struct mtd_info *mtd, int num);
extern int __get_mtd_device(struct mtd_info *mtd);
Lots (nearly all) mtd drivers contain nearly the similar code that calls parse_mtd_partitions, provides some platform-default values, if parsing fails, and registers mtd device. This is an aim to provide single implementation of this scenario: mtd_device_parse_register() which will handle all this parsing and defaults. Signed-off-by: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com> --- drivers/mtd/mtdcore.c | 40 ++++++++++++++++++++++++++++++++++++++++ include/linux/mtd/mtd.h | 5 +++++ 2 files changed, 45 insertions(+), 0 deletions(-)