Commit b824bb4b authored by Hans de Goede's avatar Hans de Goede Committed by Mauro Carvalho Chehab

[media] pwc: Get rid of error_status and unplugged variables

Having 2 ways of tracking disconnection is too much, remove both and
instead simply set pdev->udev to NULL on disconnect. Also check for
pdev->udev being NULL in all possible entry paths.
Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent 1a4ede65
...@@ -570,14 +570,7 @@ static void pwc_isoc_cleanup(struct pwc_device *pdev) ...@@ -570,14 +570,7 @@ static void pwc_isoc_cleanup(struct pwc_device *pdev)
pwc_iso_stop(pdev); pwc_iso_stop(pdev);
pwc_iso_free(pdev); pwc_iso_free(pdev);
usb_set_interface(pdev->udev, 0, 0);
/* Stop camera, but only if we are sure the camera is still there (unplug
is signalled by EPIPE)
*/
if (pdev->error_status != EPIPE) {
PWC_DEBUG_OPEN("Setting alternate interface 0.\n");
usb_set_interface(pdev->udev, 0, 0);
}
pdev->iso_init = 0; pdev->iso_init = 0;
PWC_DEBUG_OPEN("<< pwc_isoc_cleanup()\n"); PWC_DEBUG_OPEN("<< pwc_isoc_cleanup()\n");
...@@ -719,6 +712,9 @@ static int pwc_video_open(struct file *file) ...@@ -719,6 +712,9 @@ static int pwc_video_open(struct file *file)
PWC_DEBUG_OPEN(">> video_open called(vdev = 0x%p).\n", vdev); PWC_DEBUG_OPEN(">> video_open called(vdev = 0x%p).\n", vdev);
pdev = video_get_drvdata(vdev); pdev = video_get_drvdata(vdev);
if (!pdev->udev)
return -ENODEV;
if (pdev->vopen) { if (pdev->vopen) {
PWC_DEBUG_OPEN("I'm busy, someone is using the device.\n"); PWC_DEBUG_OPEN("I'm busy, someone is using the device.\n");
return -EBUSY; return -EBUSY;
...@@ -760,7 +756,6 @@ static int pwc_video_open(struct file *file) ...@@ -760,7 +756,6 @@ static int pwc_video_open(struct file *file)
/* Reset buffers & parameters */ /* Reset buffers & parameters */
pdev->visoc_errors = 0; pdev->visoc_errors = 0;
pdev->error_status = 0;
pwc_construct(pdev); /* set min/max sizes correct */ pwc_construct(pdev); /* set min/max sizes correct */
/* Set some defaults */ /* Set some defaults */
...@@ -837,7 +832,7 @@ static int pwc_video_close(struct file *file) ...@@ -837,7 +832,7 @@ static int pwc_video_close(struct file *file)
pwc_free_buffers(pdev); pwc_free_buffers(pdev);
/* Turn off LEDS and power down camera, but only when not unplugged */ /* Turn off LEDS and power down camera, but only when not unplugged */
if (!pdev->unplugged) { if (pdev->udev) {
/* Turn LEDs off */ /* Turn LEDs off */
if (pwc_set_leds(pdev, 0, 0) < 0) if (pwc_set_leds(pdev, 0, 0) < 0)
PWC_DEBUG_MODULE("Failed to set LED on/off time.\n"); PWC_DEBUG_MODULE("Failed to set LED on/off time.\n");
...@@ -859,8 +854,8 @@ static ssize_t pwc_video_read(struct file *file, char __user *buf, ...@@ -859,8 +854,8 @@ static ssize_t pwc_video_read(struct file *file, char __user *buf,
struct video_device *vdev = file->private_data; struct video_device *vdev = file->private_data;
struct pwc_device *pdev = video_get_drvdata(vdev); struct pwc_device *pdev = video_get_drvdata(vdev);
if (pdev->error_status) if (!pdev->udev)
return -pdev->error_status; return -ENODEV;
return vb2_read(&pdev->vb_queue, buf, count, ppos, return vb2_read(&pdev->vb_queue, buf, count, ppos,
file->f_flags & O_NONBLOCK); file->f_flags & O_NONBLOCK);
...@@ -871,7 +866,7 @@ static unsigned int pwc_video_poll(struct file *file, poll_table *wait) ...@@ -871,7 +866,7 @@ static unsigned int pwc_video_poll(struct file *file, poll_table *wait)
struct video_device *vdev = file->private_data; struct video_device *vdev = file->private_data;
struct pwc_device *pdev = video_get_drvdata(vdev); struct pwc_device *pdev = video_get_drvdata(vdev);
if (pdev->error_status) if (!pdev->udev)
return POLL_ERR; return POLL_ERR;
return vb2_poll(&pdev->vb_queue, file, wait); return vb2_poll(&pdev->vb_queue, file, wait);
...@@ -923,8 +918,8 @@ static int buffer_prepare(struct vb2_buffer *vb) ...@@ -923,8 +918,8 @@ static int buffer_prepare(struct vb2_buffer *vb)
struct pwc_device *pdev = vb2_get_drv_priv(vb->vb2_queue); struct pwc_device *pdev = vb2_get_drv_priv(vb->vb2_queue);
/* Don't allow queing new buffers after device disconnection */ /* Don't allow queing new buffers after device disconnection */
if (pdev->error_status) if (!pdev->udev)
return -pdev->error_status; return -ENODEV;
return 0; return 0;
} }
...@@ -964,6 +959,9 @@ static int start_streaming(struct vb2_queue *vq) ...@@ -964,6 +959,9 @@ static int start_streaming(struct vb2_queue *vq)
{ {
struct pwc_device *pdev = vb2_get_drv_priv(vq); struct pwc_device *pdev = vb2_get_drv_priv(vq);
if (!pdev->udev)
return -ENODEV;
return pwc_isoc_init(pdev); return pwc_isoc_init(pdev);
} }
...@@ -971,7 +969,8 @@ static int stop_streaming(struct vb2_queue *vq) ...@@ -971,7 +969,8 @@ static int stop_streaming(struct vb2_queue *vq)
{ {
struct pwc_device *pdev = vb2_get_drv_priv(vq); struct pwc_device *pdev = vb2_get_drv_priv(vq);
pwc_isoc_cleanup(pdev); if (pdev->udev)
pwc_isoc_cleanup(pdev);
pwc_cleanup_queued_bufs(pdev); pwc_cleanup_queued_bufs(pdev);
return 0; return 0;
...@@ -1389,15 +1388,12 @@ static void usb_pwc_disconnect(struct usb_interface *intf) ...@@ -1389,15 +1388,12 @@ static void usb_pwc_disconnect(struct usb_interface *intf)
struct pwc_device *pdev = usb_get_intfdata(intf); struct pwc_device *pdev = usb_get_intfdata(intf);
mutex_lock(&pdev->modlock); mutex_lock(&pdev->modlock);
usb_set_intfdata (intf, NULL);
/* We got unplugged; this is signalled by an EPIPE error code */
pdev->error_status = EPIPE;
pdev->unplugged = 1;
usb_set_intfdata(intf, NULL);
/* No need to keep the urbs around after disconnection */ /* No need to keep the urbs around after disconnection */
pwc_isoc_cleanup(pdev); pwc_isoc_cleanup(pdev);
pwc_cleanup_queued_bufs(pdev); pwc_cleanup_queued_bufs(pdev);
pdev->udev = NULL;
mutex_unlock(&pdev->modlock); mutex_unlock(&pdev->modlock);
......
...@@ -288,6 +288,9 @@ static int pwc_vidioc_set_fmt(struct pwc_device *pdev, struct v4l2_format *f) ...@@ -288,6 +288,9 @@ static int pwc_vidioc_set_fmt(struct pwc_device *pdev, struct v4l2_format *f)
{ {
int ret, fps, snapshot, compression, pixelformat; int ret, fps, snapshot, compression, pixelformat;
if (!pdev->udev)
return -ENODEV;
ret = pwc_vidioc_try_fmt(pdev, f); ret = pwc_vidioc_try_fmt(pdev, f);
if (ret<0) if (ret<0)
return ret; return ret;
...@@ -346,6 +349,9 @@ static int pwc_querycap(struct file *file, void *fh, struct v4l2_capability *cap ...@@ -346,6 +349,9 @@ static int pwc_querycap(struct file *file, void *fh, struct v4l2_capability *cap
struct video_device *vdev = video_devdata(file); struct video_device *vdev = video_devdata(file);
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
if (!pdev->udev)
return -ENODEV;
strcpy(cap->driver, PWC_NAME); strcpy(cap->driver, PWC_NAME);
strlcpy(cap->card, vdev->name, sizeof(cap->card)); strlcpy(cap->card, vdev->name, sizeof(cap->card));
usb_make_path(pdev->udev, cap->bus_info, sizeof(cap->bus_info)); usb_make_path(pdev->udev, cap->bus_info, sizeof(cap->bus_info));
...@@ -414,6 +420,9 @@ static int pwc_g_ctrl(struct file *file, void *fh, struct v4l2_control *c) ...@@ -414,6 +420,9 @@ static int pwc_g_ctrl(struct file *file, void *fh, struct v4l2_control *c)
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
int ret; int ret;
if (!pdev->udev)
return -ENODEV;
switch (c->id) { switch (c->id) {
case V4L2_CID_BRIGHTNESS: case V4L2_CID_BRIGHTNESS:
c->value = pwc_get_brightness(pdev); c->value = pwc_get_brightness(pdev);
...@@ -517,6 +526,9 @@ static int pwc_s_ctrl(struct file *file, void *fh, struct v4l2_control *c) ...@@ -517,6 +526,9 @@ static int pwc_s_ctrl(struct file *file, void *fh, struct v4l2_control *c)
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
int ret; int ret;
if (!pdev->udev)
return -ENODEV;
switch (c->id) { switch (c->id) {
case V4L2_CID_BRIGHTNESS: case V4L2_CID_BRIGHTNESS:
c->value <<= 9; c->value <<= 9;
...@@ -692,6 +704,9 @@ static int pwc_qbuf(struct file *file, void *fh, struct v4l2_buffer *buf) ...@@ -692,6 +704,9 @@ static int pwc_qbuf(struct file *file, void *fh, struct v4l2_buffer *buf)
{ {
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
if (!pdev->udev)
return -ENODEV;
return vb2_qbuf(&pdev->vb_queue, buf); return vb2_qbuf(&pdev->vb_queue, buf);
} }
...@@ -699,6 +714,9 @@ static int pwc_dqbuf(struct file *file, void *fh, struct v4l2_buffer *buf) ...@@ -699,6 +714,9 @@ static int pwc_dqbuf(struct file *file, void *fh, struct v4l2_buffer *buf)
{ {
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
if (!pdev->udev)
return -ENODEV;
return vb2_dqbuf(&pdev->vb_queue, buf, file->f_flags & O_NONBLOCK); return vb2_dqbuf(&pdev->vb_queue, buf, file->f_flags & O_NONBLOCK);
} }
...@@ -706,6 +724,9 @@ static int pwc_streamon(struct file *file, void *fh, enum v4l2_buf_type i) ...@@ -706,6 +724,9 @@ static int pwc_streamon(struct file *file, void *fh, enum v4l2_buf_type i)
{ {
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
if (!pdev->udev)
return -ENODEV;
return vb2_streamon(&pdev->vb_queue, i); return vb2_streamon(&pdev->vb_queue, i);
} }
...@@ -713,6 +734,9 @@ static int pwc_streamoff(struct file *file, void *fh, enum v4l2_buf_type i) ...@@ -713,6 +734,9 @@ static int pwc_streamoff(struct file *file, void *fh, enum v4l2_buf_type i)
{ {
struct pwc_device *pdev = video_drvdata(file); struct pwc_device *pdev = video_drvdata(file);
if (!pdev->udev)
return -ENODEV;
return vb2_streamoff(&pdev->vb_queue, i); return vb2_streamoff(&pdev->vb_queue, i);
} }
......
...@@ -161,7 +161,6 @@ struct pwc_device ...@@ -161,7 +161,6 @@ struct pwc_device
int release; /* release number */ int release; /* release number */
int features; /* feature bits */ int features; /* feature bits */
char serial[30]; /* serial number (string) */ char serial[30]; /* serial number (string) */
int error_status; /* set when something goes wrong */
int usb_init; /* set when the cam has been initialized */ int usb_init; /* set when the cam has been initialized */
/*** Video data ***/ /*** Video data ***/
...@@ -180,7 +179,6 @@ struct pwc_device ...@@ -180,7 +179,6 @@ struct pwc_device
char vsnapshot; /* snapshot mode */ char vsnapshot; /* snapshot mode */
char vsync; /* used by isoc handler */ char vsync; /* used by isoc handler */
char vmirror; /* for ToUCaM series */ char vmirror; /* for ToUCaM series */
char unplugged;
int cmd_len; int cmd_len;
unsigned char cmd_buf[13]; unsigned char cmd_buf[13];
......
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