aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHans Verkuil <hverkuil@xs4all.nl>2008-07-18 09:07:10 -0400
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-07-20 06:29:27 -0400
commitfac3639d886ae577d74e2da16e6a448620d432c9 (patch)
tree2771f7bd1e2f7225b451dc5a272f30b5515e90e4
parentf19ad390146e7745cbc529f3bef8469cf21f3a6b (diff)
V4L/DVB (8414): videodev/cx18: fix get_index bug and error-handling lock-ups
Fix a bug in get_index that was introduced earlier. Also fix two error handling lock-ups in videodev and cx18 that where found thanks to that bug. Signed-off-by: Hans Verkuil <hverkuil@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
-rw-r--r--drivers/media/video/cx18/cx18-streams.c4
-rw-r--r--drivers/media/video/videodev.c9
2 files changed, 8 insertions, 5 deletions
diff --git a/drivers/media/video/cx18/cx18-streams.c b/drivers/media/video/cx18/cx18-streams.c
index f3d20509a8bd..1728b1d832a9 100644
--- a/drivers/media/video/cx18/cx18-streams.c
+++ b/drivers/media/video/cx18/cx18-streams.c
@@ -311,8 +311,10 @@ void cx18_streams_cleanup(struct cx18 *cx, int unregister)
311 311
312 /* Teardown all streams */ 312 /* Teardown all streams */
313 for (type = 0; type < CX18_MAX_STREAMS; type++) { 313 for (type = 0; type < CX18_MAX_STREAMS; type++) {
314 if (cx->streams[type].dvb.enabled) 314 if (cx->streams[type].dvb.enabled) {
315 cx18_dvb_unregister(&cx->streams[type]); 315 cx18_dvb_unregister(&cx->streams[type]);
316 cx->streams[type].dvb.enabled = false;
317 }
316 318
317 vdev = cx->streams[type].v4l2dev; 319 vdev = cx->streams[type].v4l2dev;
318 320
diff --git a/drivers/media/video/videodev.c b/drivers/media/video/videodev.c
index aca36dec6746..6616e6570557 100644
--- a/drivers/media/video/videodev.c
+++ b/drivers/media/video/videodev.c
@@ -2023,7 +2023,7 @@ EXPORT_SYMBOL(video_ioctl2);
2023static int get_index(struct video_device *vdev, int num) 2023static int get_index(struct video_device *vdev, int num)
2024{ 2024{
2025 u32 used = 0; 2025 u32 used = 0;
2026 const unsigned max_index = sizeof(used) * 8 - 1; 2026 const int max_index = sizeof(used) * 8 - 1;
2027 int i; 2027 int i;
2028 2028
2029 /* Currently a single v4l driver instance cannot create more than 2029 /* Currently a single v4l driver instance cannot create more than
@@ -2145,14 +2145,15 @@ int video_register_device_index(struct video_device *vfd, int type, int nr,
2145 vfd->minor=i; 2145 vfd->minor=i;
2146 2146
2147 ret = get_index(vfd, index); 2147 ret = get_index(vfd, index);
2148 vfd->index = ret;
2149
2150 mutex_unlock(&videodev_lock);
2151
2148 if (ret < 0) { 2152 if (ret < 0) {
2149 printk(KERN_ERR "%s: get_index failed\n", __func__); 2153 printk(KERN_ERR "%s: get_index failed\n", __func__);
2150 goto fail_minor; 2154 goto fail_minor;
2151 } 2155 }
2152 2156
2153 vfd->index = ret;
2154
2155 mutex_unlock(&videodev_lock);
2156 mutex_init(&vfd->lock); 2157 mutex_init(&vfd->lock);
2157 2158
2158 /* sysfs class */ 2159 /* sysfs class */