Commit 17e7f1b5 authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

[media] saa7134: fix regression with tvtime

This solves this bug:

https://bugzilla.kernel.org/show_bug.cgi?id=73361

The problem is that when you quit tvtime it calls STREAMOFF, but then it queues a
bunch of buffers for no good reason before closing the file descriptor.

In the past closing the fd would free the vb queue since that was part of the file
handle struct. Since that was moved to the global struct that no longer happened.

This wouldn't be a problem, but the extra QBUF calls that tvtime does meant that
the buffer list in videobuf (q->stream) contained buffers, so REQBUFS would fail
with -EBUSY.

The solution is to init the list head explicitly when releasing the file
descriptor and to not free the video resource when calling streamoff.

The real fix will hopefully go into kernel 3.16 when the vb2 conversion is
merged. Basically the saa7134 driver with the old videobuf is so full of holes it
ain't funny anymore, so consider this a band-aid for kernels 3.14 and 15.
Signed-off-by: default avatarHans Verkuil <hans.verkuil@cisco.com>
Cc: stable@vger.kernel.org      # for v3.14 and up
Signed-off-by: default avatarMauro Carvalho Chehab <m.chehab@samsung.com>
parent 393cbd8d
...@@ -1243,6 +1243,7 @@ static int video_release(struct file *file) ...@@ -1243,6 +1243,7 @@ static int video_release(struct file *file)
videobuf_streamoff(&dev->cap); videobuf_streamoff(&dev->cap);
res_free(dev, fh, RESOURCE_VIDEO); res_free(dev, fh, RESOURCE_VIDEO);
videobuf_mmap_free(&dev->cap); videobuf_mmap_free(&dev->cap);
INIT_LIST_HEAD(&dev->cap.stream);
} }
if (dev->cap.read_buf) { if (dev->cap.read_buf) {
buffer_release(&dev->cap, dev->cap.read_buf); buffer_release(&dev->cap, dev->cap.read_buf);
...@@ -1254,6 +1255,7 @@ static int video_release(struct file *file) ...@@ -1254,6 +1255,7 @@ static int video_release(struct file *file)
videobuf_stop(&dev->vbi); videobuf_stop(&dev->vbi);
res_free(dev, fh, RESOURCE_VBI); res_free(dev, fh, RESOURCE_VBI);
videobuf_mmap_free(&dev->vbi); videobuf_mmap_free(&dev->vbi);
INIT_LIST_HEAD(&dev->vbi.stream);
} }
/* ts-capture will not work in planar mode, so turn it off Hac: 04.05*/ /* ts-capture will not work in planar mode, so turn it off Hac: 04.05*/
...@@ -1987,17 +1989,12 @@ int saa7134_streamoff(struct file *file, void *priv, ...@@ -1987,17 +1989,12 @@ int saa7134_streamoff(struct file *file, void *priv,
enum v4l2_buf_type type) enum v4l2_buf_type type)
{ {
struct saa7134_dev *dev = video_drvdata(file); struct saa7134_dev *dev = video_drvdata(file);
int err;
int res = saa7134_resource(file); int res = saa7134_resource(file);
if (res != RESOURCE_EMPRESS) if (res != RESOURCE_EMPRESS)
pm_qos_remove_request(&dev->qos_request); pm_qos_remove_request(&dev->qos_request);
err = videobuf_streamoff(saa7134_queue(file)); return videobuf_streamoff(saa7134_queue(file));
if (err < 0)
return err;
res_free(dev, priv, res);
return 0;
} }
EXPORT_SYMBOL_GPL(saa7134_streamoff); EXPORT_SYMBOL_GPL(saa7134_streamoff);
......
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