aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/i3c
diff options
context:
space:
mode:
authorQinglang Miao <miaoqinglang@huawei.com>2020-10-28 17:15:43 +0800
committerBoris Brezillon <boris.brezillon@collabora.com>2020-11-23 10:22:16 +0100
commit59165d16c699182b86b5c65181013f1fd88feb62 (patch)
treee0626ea55e72f08d7d466220e4e188e074346a62 /drivers/i3c
parentLinux 5.10-rc1 (diff)
downloadlinux-dev-59165d16c699182b86b5c65181013f1fd88feb62.tar.xz
linux-dev-59165d16c699182b86b5c65181013f1fd88feb62.zip
i3c master: fix missing destroy_workqueue() on error in i3c_master_register
Add the missing destroy_workqueue() before return from i3c_master_register in the error handling case. Signed-off-by: Qinglang Miao <miaoqinglang@huawei.com> Signed-off-by: Boris Brezillon <boris.brezillon@collabora.com> Link: https://lore.kernel.org/linux-i3c/20201028091543.136167-1-miaoqinglang@huawei.com
Diffstat (limited to 'drivers/i3c')
-rw-r--r--drivers/i3c/master.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/i3c/master.c b/drivers/i3c/master.c
index 1c6b78ad5ade..b61bf53ec07a 100644
--- a/drivers/i3c/master.c
+++ b/drivers/i3c/master.c
@@ -2537,7 +2537,7 @@ int i3c_master_register(struct i3c_master_controller *master,
ret = i3c_master_bus_init(master);
if (ret)
- goto err_put_dev;
+ goto err_destroy_wq;
ret = device_add(&master->dev);
if (ret)
@@ -2568,6 +2568,9 @@ err_del_dev:
err_cleanup_bus:
i3c_master_bus_cleanup(master);
+err_destroy_wq:
+ destroy_workqueue(master->wq);
+
err_put_dev:
put_device(&master->dev);