mtd: parsers: afs: Fix freeing the part name memory in failure
authorManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Mon, 4 Jan 2021 04:11:37 +0000 (09:41 +0530)
committerMiquel Raynal <miquel.raynal@bootlin.com>
Mon, 1 Feb 2021 17:58:38 +0000 (18:58 +0100)
In the case of failure while parsing the partitions, the iterator should
be pre decremented by one before starting to free the memory allocated
by kstrdup(). Because in the failure case, kstrdup() will not succeed
and thus no memory will be allocated for the current iteration.

Fixes: 1fca1f6abb38 ("mtd: afs: simplify partition parsing")
Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Cc: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Link: https://lore.kernel.org/linux-mtd/20210104041137.113075-5-manivannan.sadhasivam@linaro.org
drivers/mtd/parsers/afs.c

index 980e332bdac48f6b2ff784fef51534d431f4e9d7..26116694c821b47ff55a8ef728d4daa9d513dbbe 100644 (file)
@@ -370,10 +370,8 @@ static int parse_afs_partitions(struct mtd_info *mtd,
        return i;
 
 out_free_parts:
-       while (i >= 0) {
+       while (--i >= 0)
                kfree(parts[i].name);
-               i--;
-       }
        kfree(parts);
        *pparts = NULL;
        return ret;