Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f44dcbd0 authored by Dmitry Eremin-Solenikov's avatar Dmitry Eremin-Solenikov Committed by Artem Bityutskiy
Browse files

mtd: physmap_of.c: use mtd_device_parse_register



Replace custom invocations of parse_mtd_partitions and mtd_device_register
with common mtd_device_parse_register call. This would bring: standard
handling of all errors, fallback to default partitions, etc.

Signed-off-by: default avatarDmitry Eremin-Solenikov <dbaryshkov@gmail.com>
Signed-off-by: default avatarArtem Bityutskiy <dedekind1@gmail.com>
parent fbcf62a3
Loading
Loading
Loading
Loading
+3 −15
Original line number Original line Diff line number Diff line
@@ -34,13 +34,10 @@ struct of_flash_list {


struct of_flash {
struct of_flash {
	struct mtd_info		*cmtd;
	struct mtd_info		*cmtd;
	struct mtd_partition	*parts;
	int list_size; /* number of elements in of_flash_list */
	int list_size; /* number of elements in of_flash_list */
	struct of_flash_list	list[0];
	struct of_flash_list	list[0];
};
};


#define OF_FLASH_PARTS(info)	((info)->parts)

static int of_flash_remove(struct platform_device *dev)
static int of_flash_remove(struct platform_device *dev)
{
{
	struct of_flash *info;
	struct of_flash *info;
@@ -56,11 +53,8 @@ static int of_flash_remove(struct platform_device *dev)
		mtd_concat_destroy(info->cmtd);
		mtd_concat_destroy(info->cmtd);
	}
	}


	if (info->cmtd) {
	if (info->cmtd)
		if (OF_FLASH_PARTS(info))
			kfree(OF_FLASH_PARTS(info));
		mtd_device_unregister(info->cmtd);
		mtd_device_unregister(info->cmtd);
	}


	for (i = 0; i < info->list_size; i++) {
	for (i = 0; i < info->list_size; i++) {
		if (info->list[i].mtd)
		if (info->list[i].mtd)
@@ -290,16 +284,10 @@ static int __devinit of_flash_probe(struct platform_device *dev)


	ppdata.of_node = dp;
	ppdata.of_node = dp;
	part_probe_types = of_get_probes(dp);
	part_probe_types = of_get_probes(dp);
	err = parse_mtd_partitions(info->cmtd, part_probe_types,
	mtd_device_parse_register(info->cmtd, part_probe_types, &ppdata,
				   &info->parts, &ppdata);
			NULL, 0);
	if (err < 0) {
		of_free_probes(part_probe_types);
		goto err_out;
	}
	of_free_probes(part_probe_types);
	of_free_probes(part_probe_types);


	mtd_device_register(info->cmtd, info->parts, err);

	kfree(mtd_list);
	kfree(mtd_list);


	return 0;
	return 0;