media: dvbdev: drop refcount on error path in dvb_device_open()
authorDan Carpenter <dan.carpenter@linaro.org>
Tue, 31 Oct 2023 09:53:33 +0000 (12:53 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Jan 2024 23:35:35 +0000 (15:35 -0800)
[ Upstream commit a2dd235df435a05d389240be748909ada91201d2 ]

If call to file->f_op->open() fails, then call dvb_device_put(dvbdev).

Fixes: 0fc044b2b5e2 ("media: dvbdev: adopts refcnt to avoid UAF")
Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/media/dvb-core/dvbdev.c

index 305bb21..49f0eb7 100644 (file)
@@ -104,6 +104,8 @@ static int dvb_device_open(struct inode *inode, struct file *file)
                        err = file->f_op->open(inode, file);
                up_read(&minor_rwsem);
                mutex_unlock(&dvbdev_mutex);
+               if (err)
+                       dvb_device_put(dvbdev);
                return err;
        }
 fail: