Message ID | 1446545802-28496-3-git-send-email-jh1009.sung@samsung.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On 11/03/15 11:16, Junghak Sung wrote: > Add set_timestamp to struct vb2_queue as a flag set if vb2-core should > set timestamps. > > Signed-off-by: Junghak Sung <jh1009.sung@samsung.com> > Signed-off-by: Geunyoung Kim <nenggun.kim@samsung.com> > Acked-by: Seung-Woo Kim <sw0312.kim@samsung.com> > Acked-by: Inki Dae <inki.dae@samsung.com> > --- > drivers/media/v4l2-core/videobuf2-v4l2.c | 20 +++++++------------- > include/media/videobuf2-core.h | 2 ++ > 2 files changed, 9 insertions(+), 13 deletions(-) > > diff --git a/drivers/media/v4l2-core/videobuf2-v4l2.c b/drivers/media/v4l2-core/videobuf2-v4l2.c > index 93e16375..d254452 100644 > --- a/drivers/media/v4l2-core/videobuf2-v4l2.c > +++ b/drivers/media/v4l2-core/videobuf2-v4l2.c > @@ -118,10 +118,8 @@ static int __set_timestamp(struct vb2_buffer *vb, const void *pb) > * For output buffers copy the timestamp if needed, > * and the timecode field and flag if needed. > */ > - if ((q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == > - V4L2_BUF_FLAG_TIMESTAMP_COPY) { > + if (q->set_timestamp) > vb->timestamp = timeval_to_ns(&b->timestamp); > - } > vbuf->flags |= b->flags & V4L2_BUF_FLAG_TIMECODE; > if (b->flags & V4L2_BUF_FLAG_TIMECODE) > vbuf->timecode = b->timecode; > @@ -239,8 +237,7 @@ static int __fill_v4l2_buffer(struct vb2_buffer *vb, void *pb) > */ > b->flags &= ~V4L2_BUFFER_MASK_FLAGS; > b->flags |= q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK; > - if ((q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) != > - V4L2_BUF_FLAG_TIMESTAMP_COPY) { > + if (!q->set_timestamp) { > /* > * For non-COPY timestamps, drop timestamp source bits > * and obtain the timestamp source from the queue. > @@ -404,8 +401,7 @@ static int __fill_vb2_buffer(struct vb2_buffer *vb, > > /* Zero flags that the vb2 core handles */ > vbuf->flags = b->flags & ~V4L2_BUFFER_MASK_FLAGS; > - if ((vb->vb2_queue->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) != > - V4L2_BUF_FLAG_TIMESTAMP_COPY || !V4L2_TYPE_IS_OUTPUT(b->type)) { > + if (!vb->vb2_queue->set_timestamp || !V4L2_TYPE_IS_OUTPUT(b->type)) { > /* > * Non-COPY timestamps and non-OUTPUT queues will get > * their timestamp and timestamp source flags from the > @@ -723,6 +719,8 @@ int vb2_queue_init(struct vb2_queue *q) > q->buf_ops = &v4l2_buf_ops; > q->is_multiplanar = V4L2_TYPE_IS_MULTIPLANAR(q->type); > q->is_output = V4L2_TYPE_IS_OUTPUT(q->type); > + q->set_timestamp = (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) > + == V4L2_BUF_FLAG_TIMESTAMP_COPY; > > return vb2_core_queue_init(q); > } > @@ -1080,9 +1078,7 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_ > * should set timestamps if V4L2_BUF_FLAG_TIMESTAMP_COPY is set. Nobody > * else is able to provide this information with the write() operation. > */ > - bool set_timestamp = !read && > - (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == > - V4L2_BUF_FLAG_TIMESTAMP_COPY; > + bool set_timestamp = !read && q->set_timestamp; > int ret, index; > > dprintk(3, "mode %s, offset %ld, count %zd, %sblocking\n", > @@ -1271,9 +1267,7 @@ static int vb2_thread(void *data) > > if (q->is_output) { > prequeue = q->num_buffers; > - set_timestamp = > - (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == > - V4L2_BUF_FLAG_TIMESTAMP_COPY; > + set_timestamp = q->set_timestamp; > } > > set_freezable(); > diff --git a/include/media/videobuf2-core.h b/include/media/videobuf2-core.h > index 6404f81..b73a28a 100644 > --- a/include/media/videobuf2-core.h > +++ b/include/media/videobuf2-core.h > @@ -431,6 +431,7 @@ struct vb2_buf_ops { > * called since poll() needs to return POLLERR in that situation. > * @is_multiplanar: set if buffer type is multiplanar > * @is_output: set if buffer type is output > + * @copy_timestamp: set if vb2-core should set timestamps This says copy_timestamp, > * @last_buffer_dequeued: used in poll() and DQBUF to immediately return if the > * last decoded buffer was already dequeued. Set for capture queues > * when a buffer with the V4L2_BUF_FLAG_LAST is dequeued. > @@ -480,6 +481,7 @@ struct vb2_queue { > unsigned int waiting_for_buffers:1; > unsigned int is_multiplanar:1; > unsigned int is_output:1; > + unsigned int set_timestamp:1; while this is set_timestamp. I actually think the comment is right and this field should be called copy_timestamp. The timestamp is never actually set, it is just copied. > unsigned int last_buffer_dequeued:1; > > struct vb2_fileio_data *fileio; > Regards, Hams -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On 11/04/2015 09:41 PM, Hans Verkuil wrote: > On 11/03/15 11:16, Junghak Sung wrote: >> Add set_timestamp to struct vb2_queue as a flag set if vb2-core should >> set timestamps. >> >> Signed-off-by: Junghak Sung <jh1009.sung@samsung.com> >> Signed-off-by: Geunyoung Kim <nenggun.kim@samsung.com> >> Acked-by: Seung-Woo Kim <sw0312.kim@samsung.com> >> Acked-by: Inki Dae <inki.dae@samsung.com> >> --- >> drivers/media/v4l2-core/videobuf2-v4l2.c | 20 +++++++------------- >> include/media/videobuf2-core.h | 2 ++ >> 2 files changed, 9 insertions(+), 13 deletions(-) >> >> diff --git a/drivers/media/v4l2-core/videobuf2-v4l2.c b/drivers/media/v4l2-core/videobuf2-v4l2.c >> index 93e16375..d254452 100644 >> --- a/drivers/media/v4l2-core/videobuf2-v4l2.c >> +++ b/drivers/media/v4l2-core/videobuf2-v4l2.c >> @@ -118,10 +118,8 @@ static int __set_timestamp(struct vb2_buffer *vb, const void *pb) >> * For output buffers copy the timestamp if needed, >> * and the timecode field and flag if needed. >> */ >> - if ((q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == >> - V4L2_BUF_FLAG_TIMESTAMP_COPY) { >> + if (q->set_timestamp) >> vb->timestamp = timeval_to_ns(&b->timestamp); >> - } >> vbuf->flags |= b->flags & V4L2_BUF_FLAG_TIMECODE; >> if (b->flags & V4L2_BUF_FLAG_TIMECODE) >> vbuf->timecode = b->timecode; >> @@ -239,8 +237,7 @@ static int __fill_v4l2_buffer(struct vb2_buffer *vb, void *pb) >> */ >> b->flags &= ~V4L2_BUFFER_MASK_FLAGS; >> b->flags |= q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK; >> - if ((q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) != >> - V4L2_BUF_FLAG_TIMESTAMP_COPY) { >> + if (!q->set_timestamp) { >> /* >> * For non-COPY timestamps, drop timestamp source bits >> * and obtain the timestamp source from the queue. >> @@ -404,8 +401,7 @@ static int __fill_vb2_buffer(struct vb2_buffer *vb, >> >> /* Zero flags that the vb2 core handles */ >> vbuf->flags = b->flags & ~V4L2_BUFFER_MASK_FLAGS; >> - if ((vb->vb2_queue->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) != >> - V4L2_BUF_FLAG_TIMESTAMP_COPY || !V4L2_TYPE_IS_OUTPUT(b->type)) { >> + if (!vb->vb2_queue->set_timestamp || !V4L2_TYPE_IS_OUTPUT(b->type)) { >> /* >> * Non-COPY timestamps and non-OUTPUT queues will get >> * their timestamp and timestamp source flags from the >> @@ -723,6 +719,8 @@ int vb2_queue_init(struct vb2_queue *q) >> q->buf_ops = &v4l2_buf_ops; >> q->is_multiplanar = V4L2_TYPE_IS_MULTIPLANAR(q->type); >> q->is_output = V4L2_TYPE_IS_OUTPUT(q->type); >> + q->set_timestamp = (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) >> + == V4L2_BUF_FLAG_TIMESTAMP_COPY; >> >> return vb2_core_queue_init(q); >> } >> @@ -1080,9 +1078,7 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_ >> * should set timestamps if V4L2_BUF_FLAG_TIMESTAMP_COPY is set. Nobody >> * else is able to provide this information with the write() operation. >> */ >> - bool set_timestamp = !read && >> - (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == >> - V4L2_BUF_FLAG_TIMESTAMP_COPY; >> + bool set_timestamp = !read && q->set_timestamp; >> int ret, index; >> >> dprintk(3, "mode %s, offset %ld, count %zd, %sblocking\n", >> @@ -1271,9 +1267,7 @@ static int vb2_thread(void *data) >> >> if (q->is_output) { >> prequeue = q->num_buffers; >> - set_timestamp = >> - (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == >> - V4L2_BUF_FLAG_TIMESTAMP_COPY; >> + set_timestamp = q->set_timestamp; >> } >> >> set_freezable(); >> diff --git a/include/media/videobuf2-core.h b/include/media/videobuf2-core.h >> index 6404f81..b73a28a 100644 >> --- a/include/media/videobuf2-core.h >> +++ b/include/media/videobuf2-core.h >> @@ -431,6 +431,7 @@ struct vb2_buf_ops { >> * called since poll() needs to return POLLERR in that situation. >> * @is_multiplanar: set if buffer type is multiplanar >> * @is_output: set if buffer type is output >> + * @copy_timestamp: set if vb2-core should set timestamps > > This says copy_timestamp, > >> * @last_buffer_dequeued: used in poll() and DQBUF to immediately return if the >> * last decoded buffer was already dequeued. Set for capture queues >> * when a buffer with the V4L2_BUF_FLAG_LAST is dequeued. >> @@ -480,6 +481,7 @@ struct vb2_queue { >> unsigned int waiting_for_buffers:1; >> unsigned int is_multiplanar:1; >> unsigned int is_output:1; >> + unsigned int set_timestamp:1; > > while this is set_timestamp. > > I actually think the comment is right and this field should be called > copy_timestamp. The timestamp is never actually set, it is just copied. > OK, copy_timestamp would be better name from your review. Thank you, Hans. Best regards, Junghak >> unsigned int last_buffer_dequeued:1; >> >> struct vb2_fileio_data *fileio; >> > > Regards, > > Hams > -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/drivers/media/v4l2-core/videobuf2-v4l2.c b/drivers/media/v4l2-core/videobuf2-v4l2.c index 93e16375..d254452 100644 --- a/drivers/media/v4l2-core/videobuf2-v4l2.c +++ b/drivers/media/v4l2-core/videobuf2-v4l2.c @@ -118,10 +118,8 @@ static int __set_timestamp(struct vb2_buffer *vb, const void *pb) * For output buffers copy the timestamp if needed, * and the timecode field and flag if needed. */ - if ((q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == - V4L2_BUF_FLAG_TIMESTAMP_COPY) { + if (q->set_timestamp) vb->timestamp = timeval_to_ns(&b->timestamp); - } vbuf->flags |= b->flags & V4L2_BUF_FLAG_TIMECODE; if (b->flags & V4L2_BUF_FLAG_TIMECODE) vbuf->timecode = b->timecode; @@ -239,8 +237,7 @@ static int __fill_v4l2_buffer(struct vb2_buffer *vb, void *pb) */ b->flags &= ~V4L2_BUFFER_MASK_FLAGS; b->flags |= q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK; - if ((q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) != - V4L2_BUF_FLAG_TIMESTAMP_COPY) { + if (!q->set_timestamp) { /* * For non-COPY timestamps, drop timestamp source bits * and obtain the timestamp source from the queue. @@ -404,8 +401,7 @@ static int __fill_vb2_buffer(struct vb2_buffer *vb, /* Zero flags that the vb2 core handles */ vbuf->flags = b->flags & ~V4L2_BUFFER_MASK_FLAGS; - if ((vb->vb2_queue->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) != - V4L2_BUF_FLAG_TIMESTAMP_COPY || !V4L2_TYPE_IS_OUTPUT(b->type)) { + if (!vb->vb2_queue->set_timestamp || !V4L2_TYPE_IS_OUTPUT(b->type)) { /* * Non-COPY timestamps and non-OUTPUT queues will get * their timestamp and timestamp source flags from the @@ -723,6 +719,8 @@ int vb2_queue_init(struct vb2_queue *q) q->buf_ops = &v4l2_buf_ops; q->is_multiplanar = V4L2_TYPE_IS_MULTIPLANAR(q->type); q->is_output = V4L2_TYPE_IS_OUTPUT(q->type); + q->set_timestamp = (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) + == V4L2_BUF_FLAG_TIMESTAMP_COPY; return vb2_core_queue_init(q); } @@ -1080,9 +1078,7 @@ static size_t __vb2_perform_fileio(struct vb2_queue *q, char __user *data, size_ * should set timestamps if V4L2_BUF_FLAG_TIMESTAMP_COPY is set. Nobody * else is able to provide this information with the write() operation. */ - bool set_timestamp = !read && - (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == - V4L2_BUF_FLAG_TIMESTAMP_COPY; + bool set_timestamp = !read && q->set_timestamp; int ret, index; dprintk(3, "mode %s, offset %ld, count %zd, %sblocking\n", @@ -1271,9 +1267,7 @@ static int vb2_thread(void *data) if (q->is_output) { prequeue = q->num_buffers; - set_timestamp = - (q->timestamp_flags & V4L2_BUF_FLAG_TIMESTAMP_MASK) == - V4L2_BUF_FLAG_TIMESTAMP_COPY; + set_timestamp = q->set_timestamp; } set_freezable(); diff --git a/include/media/videobuf2-core.h b/include/media/videobuf2-core.h index 6404f81..b73a28a 100644 --- a/include/media/videobuf2-core.h +++ b/include/media/videobuf2-core.h @@ -431,6 +431,7 @@ struct vb2_buf_ops { * called since poll() needs to return POLLERR in that situation. * @is_multiplanar: set if buffer type is multiplanar * @is_output: set if buffer type is output + * @copy_timestamp: set if vb2-core should set timestamps * @last_buffer_dequeued: used in poll() and DQBUF to immediately return if the * last decoded buffer was already dequeued. Set for capture queues * when a buffer with the V4L2_BUF_FLAG_LAST is dequeued. @@ -480,6 +481,7 @@ struct vb2_queue { unsigned int waiting_for_buffers:1; unsigned int is_multiplanar:1; unsigned int is_output:1; + unsigned int set_timestamp:1; unsigned int last_buffer_dequeued:1; struct vb2_fileio_data *fileio;