diff options
Diffstat (limited to 'drivers/usb/media/vicam.c')
-rw-r--r-- | drivers/usb/media/vicam.c | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/drivers/usb/media/vicam.c b/drivers/usb/media/vicam.c index 5df144073871..8cfc47b831fb 100644 --- a/drivers/usb/media/vicam.c +++ b/drivers/usb/media/vicam.c | |||
@@ -42,6 +42,7 @@ | |||
42 | #include <linux/vmalloc.h> | 42 | #include <linux/vmalloc.h> |
43 | #include <linux/slab.h> | 43 | #include <linux/slab.h> |
44 | #include <linux/proc_fs.h> | 44 | #include <linux/proc_fs.h> |
45 | #include <linux/mutex.h> | ||
45 | #include "usbvideo.h" | 46 | #include "usbvideo.h" |
46 | 47 | ||
47 | // #define VICAM_DEBUG | 48 | // #define VICAM_DEBUG |
@@ -407,7 +408,7 @@ struct vicam_camera { | |||
407 | struct usb_device *udev; // usb device | 408 | struct usb_device *udev; // usb device |
408 | 409 | ||
409 | /* guard against simultaneous accesses to the camera */ | 410 | /* guard against simultaneous accesses to the camera */ |
410 | struct semaphore cam_lock; | 411 | struct mutex cam_lock; |
411 | 412 | ||
412 | int is_initialized; | 413 | int is_initialized; |
413 | u8 open_count; | 414 | u8 open_count; |
@@ -461,12 +462,12 @@ static int send_control_msg(struct vicam_camera *cam, | |||
461 | u16 size) | 462 | u16 size) |
462 | { | 463 | { |
463 | int status = -ENODEV; | 464 | int status = -ENODEV; |
464 | down(&cam->cam_lock); | 465 | mutex_lock(&cam->cam_lock); |
465 | if (cam->udev) { | 466 | if (cam->udev) { |
466 | status = __send_control_msg(cam, request, value, | 467 | status = __send_control_msg(cam, request, value, |
467 | index, cp, size); | 468 | index, cp, size); |
468 | } | 469 | } |
469 | up(&cam->cam_lock); | 470 | mutex_unlock(&cam->cam_lock); |
470 | return status; | 471 | return status; |
471 | } | 472 | } |
472 | static int | 473 | static int |
@@ -831,13 +832,13 @@ vicam_close(struct inode *inode, struct file *file) | |||
831 | rvfree(cam->framebuf, VICAM_MAX_FRAME_SIZE * VICAM_FRAMES); | 832 | rvfree(cam->framebuf, VICAM_MAX_FRAME_SIZE * VICAM_FRAMES); |
832 | kfree(cam->cntrlbuf); | 833 | kfree(cam->cntrlbuf); |
833 | 834 | ||
834 | down(&cam->cam_lock); | 835 | mutex_lock(&cam->cam_lock); |
835 | 836 | ||
836 | cam->open_count--; | 837 | cam->open_count--; |
837 | open_count = cam->open_count; | 838 | open_count = cam->open_count; |
838 | udev = cam->udev; | 839 | udev = cam->udev; |
839 | 840 | ||
840 | up(&cam->cam_lock); | 841 | mutex_unlock(&cam->cam_lock); |
841 | 842 | ||
842 | if (!open_count && !udev) { | 843 | if (!open_count && !udev) { |
843 | kfree(cam); | 844 | kfree(cam); |
@@ -960,7 +961,7 @@ read_frame(struct vicam_camera *cam, int framenum) | |||
960 | request[8] = 0; | 961 | request[8] = 0; |
961 | // bytes 9-15 do not seem to affect exposure or image quality | 962 | // bytes 9-15 do not seem to affect exposure or image quality |
962 | 963 | ||
963 | down(&cam->cam_lock); | 964 | mutex_lock(&cam->cam_lock); |
964 | 965 | ||
965 | if (!cam->udev) { | 966 | if (!cam->udev) { |
966 | goto done; | 967 | goto done; |
@@ -985,7 +986,7 @@ read_frame(struct vicam_camera *cam, int framenum) | |||
985 | } | 986 | } |
986 | 987 | ||
987 | done: | 988 | done: |
988 | up(&cam->cam_lock); | 989 | mutex_unlock(&cam->cam_lock); |
989 | } | 990 | } |
990 | 991 | ||
991 | static ssize_t | 992 | static ssize_t |
@@ -1309,7 +1310,7 @@ vicam_probe( struct usb_interface *intf, const struct usb_device_id *id) | |||
1309 | 1310 | ||
1310 | cam->shutter_speed = 15; | 1311 | cam->shutter_speed = 15; |
1311 | 1312 | ||
1312 | init_MUTEX(&cam->cam_lock); | 1313 | mutex_init(&cam->cam_lock); |
1313 | 1314 | ||
1314 | memcpy(&cam->vdev, &vicam_template, | 1315 | memcpy(&cam->vdev, &vicam_template, |
1315 | sizeof (vicam_template)); | 1316 | sizeof (vicam_template)); |
@@ -1351,7 +1352,7 @@ vicam_disconnect(struct usb_interface *intf) | |||
1351 | 1352 | ||
1352 | /* stop the camera from being used */ | 1353 | /* stop the camera from being used */ |
1353 | 1354 | ||
1354 | down(&cam->cam_lock); | 1355 | mutex_lock(&cam->cam_lock); |
1355 | 1356 | ||
1356 | /* mark the camera as gone */ | 1357 | /* mark the camera as gone */ |
1357 | 1358 | ||
@@ -1368,7 +1369,7 @@ vicam_disconnect(struct usb_interface *intf) | |||
1368 | 1369 | ||
1369 | open_count = cam->open_count; | 1370 | open_count = cam->open_count; |
1370 | 1371 | ||
1371 | up(&cam->cam_lock); | 1372 | mutex_unlock(&cam->cam_lock); |
1372 | 1373 | ||
1373 | if (!open_count) { | 1374 | if (!open_count) { |
1374 | kfree(cam); | 1375 | kfree(cam); |