]> git.baikalelectronics.ru Git - kernel.git/commitdiff
HSI: omap_ssi_core: fix possible memory leak in ssi_probe()
authorYang Yingliang <yangyingliang@huawei.com>
Mon, 31 Oct 2022 07:43:37 +0000 (15:43 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 18 Jan 2023 10:41:27 +0000 (11:41 +0100)
[ Upstream commit 1aff514e1d2bd47854dbbdf867970b9d463d4c57 ]

If ssi_add_controller() returns error, it should call hsi_put_controller()
to give up the reference that was set in hsi_alloc_controller(), so that
it can call hsi_controller_release() to free controller and ports that
allocated in hsi_alloc_controller().

Fixes: f6a17db405d3 ("HSI: Introduce OMAP SSI driver")
Signed-off-by: Yang Yingliang <yangyingliang@huawei.com>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/hsi/controllers/omap_ssi_core.c

index 8b8d25c7dc5052b4be776492416dd6d7bd9925c6..aca80357ccaa0b74dfb6fe6d2590503041d2a903 100644 (file)
@@ -502,8 +502,10 @@ static int ssi_probe(struct platform_device *pd)
        platform_set_drvdata(pd, ssi);
 
        err = ssi_add_controller(ssi, pd);
-       if (err < 0)
+       if (err < 0) {
+               hsi_put_controller(ssi);
                goto out1;
+       }
 
        pm_runtime_enable(&pd->dev);