|
@@ -1918,14 +1918,14 @@ static int em28xx_v4l2_fini(struct em28xx *dev)
|
|
|
video_unregister_device(dev->vdev);
|
|
video_unregister_device(dev->vdev);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ v4l2_ctrl_handler_free(&dev->ctrl_handler);
|
|
|
|
|
+ v4l2_device_unregister(&dev->v4l2_dev);
|
|
|
|
|
+
|
|
|
if (dev->clk) {
|
|
if (dev->clk) {
|
|
|
v4l2_clk_unregister_fixed(dev->clk);
|
|
v4l2_clk_unregister_fixed(dev->clk);
|
|
|
dev->clk = NULL;
|
|
dev->clk = NULL;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- v4l2_ctrl_handler_free(&dev->ctrl_handler);
|
|
|
|
|
- v4l2_device_unregister(&dev->v4l2_dev);
|
|
|
|
|
-
|
|
|
|
|
if (dev->users)
|
|
if (dev->users)
|
|
|
em28xx_warn("Device is open ! Memory deallocation is deferred on last close.\n");
|
|
em28xx_warn("Device is open ! Memory deallocation is deferred on last close.\n");
|
|
|
mutex_unlock(&dev->lock);
|
|
mutex_unlock(&dev->lock);
|