From: Jianglei Nie Date: Wed, 29 Jun 2022 07:55:50 +0000 (+0800) Subject: net: sfp: fix memory leak in sfp_probe() X-Git-Tag: v6.1-rc5~973^2~4 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=0a18d802d65cf662644fd1d369c86d84a5630652;p=platform%2Fkernel%2Flinux-starfive.git net: sfp: fix memory leak in sfp_probe() sfp_probe() allocates a memory chunk from sfp with sfp_alloc(). When devm_add_action() fails, sfp is not freed, which leads to a memory leak. We should use devm_add_action_or_reset() instead of devm_add_action(). Signed-off-by: Jianglei Nie Reviewed-by: Russell King (Oracle) Link: https://lore.kernel.org/r/20220629075550.2152003-1-niejianglei2021@163.com Signed-off-by: Paolo Abeni --- diff --git a/drivers/net/phy/sfp.c b/drivers/net/phy/sfp.c index 9a5d5a1..e7b0e12 100644 --- a/drivers/net/phy/sfp.c +++ b/drivers/net/phy/sfp.c @@ -2516,7 +2516,7 @@ static int sfp_probe(struct platform_device *pdev) platform_set_drvdata(pdev, sfp); - err = devm_add_action(sfp->dev, sfp_cleanup, sfp); + err = devm_add_action_or_reset(sfp->dev, sfp_cleanup, sfp); if (err < 0) return err;