Commit 2f8c0810 authored by Hans Verkuil's avatar Hans Verkuil Committed by Mauro Carvalho Chehab

media: vb2: set owner before calling vb2_read

Before vb2_read is called, the owner must be set since vb2_read will
actually start streaming. If vb2_read returns an error and q->fileio is
NULL, then it failed to start streaming and the owner is set back to NULL.

When the vb2 start_streaming callback is called, it expects the owner
pointer to be set, and that wasn't the case in this particular situation.
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 55f1ecb1
...@@ -1171,10 +1171,11 @@ ssize_t vb2_fop_read(struct file *file, char __user *buf, ...@@ -1171,10 +1171,11 @@ ssize_t vb2_fop_read(struct file *file, char __user *buf,
return -ERESTARTSYS; return -ERESTARTSYS;
if (vb2_queue_is_busy(vdev->queue, file)) if (vb2_queue_is_busy(vdev->queue, file))
goto exit; goto exit;
vdev->queue->owner = file->private_data;
err = vb2_read(vdev->queue, buf, count, ppos, err = vb2_read(vdev->queue, buf, count, ppos,
file->f_flags & O_NONBLOCK); file->f_flags & O_NONBLOCK);
if (vdev->queue->fileio) if (!vdev->queue->fileio)
vdev->queue->owner = file->private_data; vdev->queue->owner = NULL;
exit: exit:
if (lock) if (lock)
mutex_unlock(lock); mutex_unlock(lock);
......
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