From: Gustavo Padovan <gustavo@padovan.org>
To: Hans Verkuil <hverkuil@xs4all.nl>
Cc: linux-media@vger.kernel.org,
Javier Martinez Canillas <javier@osg.samsung.com>,
Mauro Carvalho Chehab <mchehab@osg.samsung.com>,
Shuah Khan <shuahkh@osg.samsung.com>,
Gustavo Padovan <gustavo.padovan@collabora.com>
Subject: Re: [PATCH 02/12] [media] vb2: split out queueing from vb_core_qbuf()
Date: Thu, 6 Jul 2017 22:04:45 -0300 [thread overview]
Message-ID: <20170707010445.GB10284@jade> (raw)
In-Reply-To: <8969cb24-95cc-3056-e6ad-8990801f326d@xs4all.nl>
2017-07-06 Hans Verkuil <hverkuil@xs4all.nl>:
> On 06/16/17 09:39, Gustavo Padovan wrote:
> > From: Gustavo Padovan <gustavo.padovan@collabora.com>
> >
> > In order to support explicit synchronization we need to divide
> > vb2_core_qbuf() in two parts, one to be executed before the fence
> > signals and another one to do the actual queueing of the buffer.
> >
> > Signed-off-by: Gustavo Padovan <gustavo.padovan@collabora.com>
> > ---
> > drivers/media/v4l2-core/videobuf2-core.c | 51 ++++++++++++++++++--------------
> > 1 file changed, 29 insertions(+), 22 deletions(-)
> >
> > diff --git a/drivers/media/v4l2-core/videobuf2-core.c b/drivers/media/v4l2-core/videobuf2-core.c
> > index 3107e21..ea83126 100644
> > --- a/drivers/media/v4l2-core/videobuf2-core.c
> > +++ b/drivers/media/v4l2-core/videobuf2-core.c
> > @@ -1367,6 +1367,34 @@ static int vb2_start_streaming(struct vb2_queue *q)
> > return ret;
> > }
> >
> > +static int __vb2_core_qbuf(struct vb2_buffer *vb, struct vb2_queue *q)
> > +{
> > + int ret;
> > +
> > + /*
> > + * If already streaming, give the buffer to driver for processing.
> > + * If not, the buffer will be given to driver on next streamon.
> > + */
> > + if (q->start_streaming_called)
> > + __enqueue_in_driver(vb);
> > +
> > + /*
> > + * If streamon has been called, and we haven't yet called
> > + * start_streaming() since not enough buffers were queued, and
> > + * we now have reached the minimum number of queued buffers,
> > + * then we can finally call start_streaming().
> > + */
> > + if (q->streaming && !q->start_streaming_called &&
> > + q->queued_count >= q->min_buffers_needed) {
> > + ret = vb2_start_streaming(q);
> > + if (ret)
> > + return ret;
> > + }
> > +
> > + dprintk(1, "qbuf of buffer %d succeeded\n", vb->index);
> > + return 0;
> > +}
> > +
> > int vb2_core_qbuf(struct vb2_queue *q, unsigned int index, void *pb)
> > {
> > struct vb2_buffer *vb;
> > @@ -1404,32 +1432,11 @@ int vb2_core_qbuf(struct vb2_queue *q, unsigned int index, void *pb)
> >
> > trace_vb2_qbuf(q, vb);
> >
> > - /*
> > - * If already streaming, give the buffer to driver for processing.
> > - * If not, the buffer will be given to driver on next streamon.
> > - */
> > - if (q->start_streaming_called)
> > - __enqueue_in_driver(vb);
> > -
> > /* Fill buffer information for the userspace */
> > if (pb)
> > call_void_bufop(q, fill_user_buffer, vb, pb);
>
> This should be called *after* the __vb2_core_qbuf call. That call changes
> vb->state which is used by buffer to fill in v4l2_buffer. So the order
> should be swapped here to ensure we return the latest state of the buffer.
I didn't pay attention to that detail. The reason why I put it here is
that later when in-fences are introduced we will only call
__vb2_core_qbuf() after the fence signals and that may happen after we
returned to userspace. I'll look into possible ways to solve this
problem.
Gustavo
next prev parent reply other threads:[~2017-07-07 1:04 UTC|newest]
Thread overview: 62+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-06-16 7:39 [PATCH 00/12] V4L2 explicit synchronization support Gustavo Padovan
2017-06-16 7:39 ` [PATCH 01/12] [media] vb2: add explicit fence user API Gustavo Padovan
2017-06-18 14:09 ` kbuild test robot
2017-06-18 14:58 ` kbuild test robot
2017-06-26 15:39 ` Gustavo Padovan
2017-07-04 5:57 ` Tomasz Figa
2017-07-04 6:27 ` Alexandre Courbot
2017-06-30 11:12 ` Mauro Carvalho Chehab
2017-06-16 7:39 ` [PATCH 02/12] [media] vb2: split out queueing from vb_core_qbuf() Gustavo Padovan
2017-06-30 11:15 ` Mauro Carvalho Chehab
2017-07-06 7:46 ` Hans Verkuil
2017-07-07 1:04 ` Gustavo Padovan [this message]
2017-06-16 7:39 ` [PATCH 03/12] [media] vb2: add in-fence support to QBUF Gustavo Padovan
2017-06-18 15:36 ` kbuild test robot
2017-06-30 11:53 ` Mauro Carvalho Chehab
2017-07-03 18:16 ` Gustavo Padovan
2017-07-06 9:43 ` Hans Verkuil
2017-07-07 1:12 ` Gustavo Padovan
2017-07-06 8:29 ` Hans Verkuil
2017-07-07 1:53 ` Gustavo Padovan
2017-07-07 7:15 ` Hans Verkuil
2017-07-10 19:27 ` Gustavo Padovan
2017-07-06 9:18 ` Hans Verkuil
2017-07-07 2:00 ` Gustavo Padovan
2017-07-07 7:06 ` Hans Verkuil
2017-07-10 19:02 ` Gustavo Padovan
2017-07-10 20:26 ` Gustavo Padovan
2017-07-11 5:57 ` Hans Verkuil
2017-07-11 12:56 ` Gustavo Padovan
2017-06-16 7:39 ` [PATCH 04/12] [media] uvc: enable subscriptions to other events Gustavo Padovan
2017-07-07 14:38 ` Shuah Khan
2017-07-10 19:38 ` Gustavo Padovan
2017-07-26 0:26 ` Gustavo Padovan
2017-06-16 7:39 ` [PATCH 05/12] [media] vivid: assign the specific device to the vb2_queue->dev Gustavo Padovan
2017-07-06 8:36 ` Hans Verkuil
2017-07-07 17:15 ` Shuah Khan
2017-07-10 19:42 ` Gustavo Padovan
2017-07-26 0:17 ` Gustavo Padovan
2017-06-16 7:39 ` [PATCH 06/12] [media] v4l: add V4L2_EVENT_BUF_QUEUED event Gustavo Padovan
2017-06-30 12:00 ` Mauro Carvalho Chehab
2017-06-16 7:39 ` [PATCH 07/12] [media] v4l: add support to BUF_QUEUED event Gustavo Padovan
2017-06-30 12:04 ` Mauro Carvalho Chehab
2017-07-03 18:36 ` Gustavo Padovan
2017-07-06 9:34 ` Hans Verkuil
2017-07-10 19:45 ` Gustavo Padovan
2017-07-06 8:47 ` Hans Verkuil
2017-06-16 7:39 ` [PATCH 08/12] [media] vb2: add 'ordered' property to queues Gustavo Padovan
2017-06-16 16:56 ` Nicolas Dufresne
2017-06-26 15:22 ` Gustavo Padovan
2017-07-06 9:08 ` Hans Verkuil
2017-06-16 7:39 ` [PATCH 09/12] [media] vivid: mark vivid queues as ordered Gustavo Padovan
2017-07-06 8:37 ` Hans Verkuil
2017-07-07 17:31 ` Shuah Khan
2017-07-10 19:47 ` Gustavo Padovan
2017-06-16 7:39 ` [PATCH 10/12] [media] vb2: add videobuf2 dma-buf fence helpers Gustavo Padovan
2017-06-16 7:39 ` [PATCH 11/12] [media] vb2: add infrastructure to support out-fences Gustavo Padovan
2017-06-16 7:39 ` [PATCH 12/12] [media] vb2: add out-fence support to QBUF Gustavo Padovan
2017-07-06 9:27 ` Hans Verkuil
2017-07-06 9:29 ` Hans Verkuil
2017-07-10 20:19 ` Gustavo Padovan
2017-06-30 12:18 ` [PATCH 00/12] V4L2 explicit synchronization support Mauro Carvalho Chehab
2017-07-03 18:40 ` Gustavo Padovan
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170707010445.GB10284@jade \
--to=gustavo@padovan.org \
--cc=gustavo.padovan@collabora.com \
--cc=hverkuil@xs4all.nl \
--cc=javier@osg.samsung.com \
--cc=linux-media@vger.kernel.org \
--cc=mchehab@osg.samsung.com \
--cc=shuahkh@osg.samsung.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.