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

Commit 4d523b60 authored by Jason Liu's avatar Jason Liu Committed by Artem Bityutskiy
Browse files

mtd: check parts pointer before using it



The code has the check for parts but it called after kmemdup,
kmemdup(parts, sizeof(*parts) * nr_parts,...)
if (!parts)
	return -ENOMEM

In fact, we need check parts before safely using it.
and we also need check the real_parts to make sure kmemdup
allocation sucessfully.

Signed-off-by: default avatarJason Liu <jason.hui@linaro.org>
Signed-off-by: default avatarArtem Bityutskiy <artem.bityutskiy@intel.com>
parent e2e24e8e
Loading
Loading
Loading
Loading
+4 −3
Original line number Diff line number Diff line
@@ -465,12 +465,13 @@ int mtd_device_parse_register(struct mtd_info *mtd, const char **types,
	struct mtd_partition *real_parts;

	err = parse_mtd_partitions(mtd, types, &real_parts, parser_data);
	if (err <= 0 && nr_parts) {
	if (err <= 0 && nr_parts && parts) {
		real_parts = kmemdup(parts, sizeof(*parts) * nr_parts,
				     GFP_KERNEL);
		err = nr_parts;
		if (!parts)
		if (!real_parts)
			err = -ENOMEM;
		else
			err = nr_parts;
	}

	if (err > 0) {