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)
committerSebastian Reichel <sre@kernel.org>
Thu, 17 Nov 2022 21:49:39 +0000 (22:49 +0100)
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: b209e047bc74 ("HSI: Introduce OMAP SSI driver")
Signed-off-by: Yang Yingliang <yangyingliang@huawei.com>
Signed-off-by: Sebastian Reichel <sebastian.reichel@collabora.com>
drivers/hsi/controllers/omap_ssi_core.c

index b23a576..052cf3e 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);