Re: [PATCHv17 28/34] videobuf2-v4l2: refuse qbuf if queue uses requests or vv.

2018-08-13 Thread Mauro Carvalho Chehab
Em Sat,  4 Aug 2018 14:45:20 +0200
Hans Verkuil  escreveu:

> From: Hans Verkuil 
> 
> Check if the vb2 queue uses requests, and if so refuse to
> add buffers that are not part of a request. Also check for
> the reverse: a vb2 queue did not use requests, and an attempt
> was made to queue a buffer to a request.
> 
> We might relax this in the future, but for now just return
> -EPERM in that case.
> 
> Signed-off-by: Hans Verkuil 
Reviewed-by: Mauro Carvalho Chehab 
> ---
>  drivers/media/common/videobuf2/videobuf2-v4l2.c | 10 +-
>  1 file changed, 9 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/media/common/videobuf2/videobuf2-v4l2.c 
> b/drivers/media/common/videobuf2/videobuf2-v4l2.c
> index 88d8f60c742b..1b2351986230 100644
> --- a/drivers/media/common/videobuf2/videobuf2-v4l2.c
> +++ b/drivers/media/common/videobuf2/videobuf2-v4l2.c
> @@ -378,8 +378,16 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, 
> struct media_device *md
>   return ret;
>   }
>  
> - if (!(b->flags & V4L2_BUF_FLAG_REQUEST_FD))
> + if (!(b->flags & V4L2_BUF_FLAG_REQUEST_FD)) {
> + if (q->uses_requests) {
> + dprintk(1, "%s: queue uses requests\n", opname);
> + return -EPERM;
> + }
>   return 0;
> + } else if (q->uses_qbuf) {
> + dprintk(1, "%s: queue does not use requests\n", opname);
> + return -EPERM;
> + }
>  
>   /*
>* For proper locking when queueing a request you need to be able



Thanks,
Mauro


[PATCHv17 28/34] videobuf2-v4l2: refuse qbuf if queue uses requests or vv.

2018-08-04 Thread Hans Verkuil
From: Hans Verkuil 

Check if the vb2 queue uses requests, and if so refuse to
add buffers that are not part of a request. Also check for
the reverse: a vb2 queue did not use requests, and an attempt
was made to queue a buffer to a request.

We might relax this in the future, but for now just return
-EPERM in that case.

Signed-off-by: Hans Verkuil 
---
 drivers/media/common/videobuf2/videobuf2-v4l2.c | 10 +-
 1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/drivers/media/common/videobuf2/videobuf2-v4l2.c 
b/drivers/media/common/videobuf2/videobuf2-v4l2.c
index 88d8f60c742b..1b2351986230 100644
--- a/drivers/media/common/videobuf2/videobuf2-v4l2.c
+++ b/drivers/media/common/videobuf2/videobuf2-v4l2.c
@@ -378,8 +378,16 @@ static int vb2_queue_or_prepare_buf(struct vb2_queue *q, 
struct media_device *md
return ret;
}
 
-   if (!(b->flags & V4L2_BUF_FLAG_REQUEST_FD))
+   if (!(b->flags & V4L2_BUF_FLAG_REQUEST_FD)) {
+   if (q->uses_requests) {
+   dprintk(1, "%s: queue uses requests\n", opname);
+   return -EPERM;
+   }
return 0;
+   } else if (q->uses_qbuf) {
+   dprintk(1, "%s: queue does not use requests\n", opname);
+   return -EPERM;
+   }
 
/*
 * For proper locking when queueing a request you need to be able
-- 
2.18.0