Commit cf0b276f authored by John Tyner's avatar John Tyner Committed by Greg Kroah-Hartman

[PATCH] USB vicam.c: minor fixes

This patch fixes some things that have failed to go in as part of other
patches that have been rejected. Namely, this adds the forgotten up call
in the read function, removes the usb_put_dev (since there is no
usb_get_dev), and also moves the allocation and freeing of the image and
frame buffers to the open and close calls only.
parent a71a78d8
...@@ -761,23 +761,19 @@ vicam_open(struct inode *inode, struct file *file) ...@@ -761,23 +761,19 @@ vicam_open(struct inode *inode, struct file *file)
return -EBUSY; return -EBUSY;
} }
cam->raw_image = kmalloc(VICAM_MAX_READ_SIZE, GFP_KERNEL);
if (!cam->raw_image) { if (!cam->raw_image) {
cam->raw_image = kmalloc(VICAM_MAX_READ_SIZE, GFP_KERNEL); up(&cam->busy_lock);
if (!cam->raw_image) { return -ENOMEM;
up(&cam->busy_lock);
return -ENOMEM;
}
} }
cam->framebuf = rvmalloc(VICAM_MAX_FRAME_SIZE * VICAM_FRAMES);
if (!cam->framebuf) { if (!cam->framebuf) {
cam->framebuf = kfree(cam->raw_image);
rvmalloc(VICAM_MAX_FRAME_SIZE * VICAM_FRAMES); up(&cam->busy_lock);
if (!cam->framebuf) { return -ENOMEM;
kfree(cam->raw_image);
up(&cam->busy_lock);
return -ENOMEM;
}
} }
// First upload firmware, then turn the camera on // First upload firmware, then turn the camera on
if (!cam->is_initialized) { if (!cam->is_initialized) {
...@@ -805,6 +801,9 @@ vicam_close(struct inode *inode, struct file *file) ...@@ -805,6 +801,9 @@ vicam_close(struct inode *inode, struct file *file)
DBG("close\n"); DBG("close\n");
set_camera_power(cam, 0); set_camera_power(cam, 0);
kfree(cam->raw_image);
rvfree(cam->framebuf, VICAM_MAX_FRAME_SIZE * VICAM_FRAMES);
cam->open_count--; cam->open_count--;
return 0; return 0;
...@@ -989,6 +988,7 @@ vicam_read( struct file *file, char *buf, size_t count, loff_t *ppos ) ...@@ -989,6 +988,7 @@ vicam_read( struct file *file, char *buf, size_t count, loff_t *ppos )
if (*ppos >= VICAM_MAX_FRAME_SIZE) { if (*ppos >= VICAM_MAX_FRAME_SIZE) {
*ppos = 0; *ppos = 0;
up(&cam->busy_lock);
return 0; return 0;
} }
...@@ -1038,15 +1038,6 @@ vicam_mmap(struct file *file, struct vm_area_struct *vma) ...@@ -1038,15 +1038,6 @@ vicam_mmap(struct file *file, struct vm_area_struct *vma)
if (down_interruptible(&cam->busy_lock)) if (down_interruptible(&cam->busy_lock))
return -EINTR; return -EINTR;
if (!cam->framebuf) { /* we do lazy allocation */
cam->framebuf =
rvmalloc(VICAM_MAX_FRAME_SIZE * VICAM_FRAMES);
if (!cam->framebuf) {
up(&cam->busy_lock);
return -ENOMEM;
}
}
pos = (unsigned long)cam->framebuf; pos = (unsigned long)cam->framebuf;
while (size > 0) { while (size > 0) {
page = kvirt_to_pa(pos); page = kvirt_to_pa(pos);
...@@ -1319,7 +1310,6 @@ vicam_disconnect(struct usb_interface *intf) ...@@ -1319,7 +1310,6 @@ vicam_disconnect(struct usb_interface *intf)
struct vicam_camera *cam = dev_get_drvdata(&intf->dev); struct vicam_camera *cam = dev_get_drvdata(&intf->dev);
dev_set_drvdata ( &intf->dev, NULL ); dev_set_drvdata ( &intf->dev, NULL );
usb_put_dev(cam->udev);
cam->udev = NULL; cam->udev = NULL;
...@@ -1329,12 +1319,6 @@ vicam_disconnect(struct usb_interface *intf) ...@@ -1329,12 +1319,6 @@ vicam_disconnect(struct usb_interface *intf)
vicam_destroy_proc_entry(cam); vicam_destroy_proc_entry(cam);
#endif #endif
if (cam->raw_image)
kfree(cam->raw_image);
if (cam->framebuf)
rvfree(cam->framebuf,
VICAM_MAX_FRAME_SIZE * VICAM_FRAMES);
kfree(cam); kfree(cam);
printk(KERN_DEBUG "ViCam-based WebCam disconnected\n"); printk(KERN_DEBUG "ViCam-based WebCam disconnected\n");
......
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