]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
mtd: rawnand: mtk: Fix init error path
authorMiquel Raynal <miquel.raynal@bootlin.com>
Mon, 26 Aug 2024 15:30:19 +0000 (17:30 +0200)
committerMiquel Raynal <miquel.raynal@bootlin.com>
Mon, 9 Sep 2024 09:51:50 +0000 (11:51 +0200)
Reviewing a series converting the for_each_chil_of_node() loops into
their _scoped variants made me realize there was no cleanup of the
already registered NAND devices upon error which may leak memory on
systems with more than a chip when this error occurs. We should call the
_nand_chips_cleanup() function when this happens.

Fixes: 1d6b1e464950 ("mtd: mediatek: driver for MTK Smart Device")
Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Reviewed-by: Pratyush Yadav <pratyush@kernel.org>
Reviewed-by: Matthias Brugger <matthias.bgg@kernel.org>
Link: https://lore.kernel.org/linux-mtd/20240826153019.67106-2-miquel.raynal@bootlin.com
drivers/mtd/nand/raw/mtk_nand.c

index bf845dd167374076215f57562ef81f2c39d1db04..586868b4139f51172d0f7418f76e0057860c7134 100644 (file)
@@ -1453,8 +1453,10 @@ static int mtk_nfc_nand_chips_init(struct device *dev, struct mtk_nfc *nfc)
 
        for_each_child_of_node_scoped(np, nand_np) {
                ret = mtk_nfc_nand_chip_init(dev, nfc, nand_np);
-               if (ret)
+               if (ret) {
+                       mtk_nfc_nand_chips_cleanup(nfc);
                        return ret;
+               }
        }
 
        return 0;