Commit d5eec231 authored by Antti Palosaari's avatar Antti Palosaari Committed by Mauro Carvalho Chehab

[media] rtl2832_sdr: refcount to rtl28xxu

We are consumer of DVB frontend provided by rtl28xxu module. Due to
that we must use refcount to ensure none could remove rtl28xxu when
we are alive (or when we are streaming, if more fine-grained
refcounting is wanted).
Signed-off-by: default avatarAntti Palosaari <crope@iki.fi>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 6a53fa23
...@@ -1310,10 +1310,21 @@ static int rtl2832_sdr_probe(struct platform_device *pdev) ...@@ -1310,10 +1310,21 @@ static int rtl2832_sdr_probe(struct platform_device *pdev)
ret = -EINVAL; ret = -EINVAL;
goto err; goto err;
} }
if (!pdev->dev.parent->driver) {
dev_dbg(&pdev->dev, "No parent device\n");
ret = -EINVAL;
goto err;
}
/* try to refcount host drv since we are the consumer */
if (!try_module_get(pdev->dev.parent->driver->owner)) {
dev_err(&pdev->dev, "Refcount fail");
ret = -EINVAL;
goto err;
}
dev = kzalloc(sizeof(*dev), GFP_KERNEL); dev = kzalloc(sizeof(*dev), GFP_KERNEL);
if (dev == NULL) { if (dev == NULL) {
ret = -ENOMEM; ret = -ENOMEM;
goto err; goto err_module_put;
} }
/* setup the state */ /* setup the state */
...@@ -1426,6 +1437,8 @@ static int rtl2832_sdr_probe(struct platform_device *pdev) ...@@ -1426,6 +1437,8 @@ static int rtl2832_sdr_probe(struct platform_device *pdev)
v4l2_ctrl_handler_free(&dev->hdl); v4l2_ctrl_handler_free(&dev->hdl);
err_kfree: err_kfree:
kfree(dev); kfree(dev);
err_module_put:
module_put(pdev->dev.parent->driver->owner);
err: err:
return ret; return ret;
} }
...@@ -1444,8 +1457,8 @@ static int rtl2832_sdr_remove(struct platform_device *pdev) ...@@ -1444,8 +1457,8 @@ static int rtl2832_sdr_remove(struct platform_device *pdev)
video_unregister_device(&dev->vdev); video_unregister_device(&dev->vdev);
mutex_unlock(&dev->v4l2_lock); mutex_unlock(&dev->v4l2_lock);
mutex_unlock(&dev->vb_queue_lock); mutex_unlock(&dev->vb_queue_lock);
v4l2_device_put(&dev->v4l2_dev); v4l2_device_put(&dev->v4l2_dev);
module_put(pdev->dev.parent->driver->owner);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment