Em Sat, 4 Aug 2018 14:45:13 +0200 Hans Verkuil <hverkuil@xxxxxxxxx> escreveu: > From: Hans Verkuil <hans.verkuil@xxxxxxxxx> > > We need to initialize the request_fd field in struct vb2_v4l2_buffer > to -1 instead of the default of 0. So we need to add a new op that > is called when struct vb2_v4l2_buffer is allocated. > > Signed-off-by: Hans Verkuil <hans.verkuil@xxxxxxxxx> Reviewed-by: Mauro Carvalho Chehab <mchehab+samsung@xxxxxxxxxx> > --- > drivers/media/common/videobuf2/videobuf2-core.c | 2 ++ > include/media/videobuf2-core.h | 4 ++++ > 2 files changed, 6 insertions(+) > > diff --git a/drivers/media/common/videobuf2/videobuf2-core.c b/drivers/media/common/videobuf2/videobuf2-core.c > index eead693ba619..230f83d6d094 100644 > --- a/drivers/media/common/videobuf2/videobuf2-core.c > +++ b/drivers/media/common/videobuf2/videobuf2-core.c > @@ -356,6 +356,8 @@ static int __vb2_queue_alloc(struct vb2_queue *q, enum vb2_memory memory, > vb->planes[plane].length = plane_sizes[plane]; > vb->planes[plane].min_length = plane_sizes[plane]; > } > + call_void_bufop(q, init_buffer, vb); > + > q->bufs[vb->index] = vb; > > /* Allocate video buffer memory for the MMAP type */ > diff --git a/include/media/videobuf2-core.h b/include/media/videobuf2-core.h > index 5e760d5f280a..cbda3968d018 100644 > --- a/include/media/videobuf2-core.h > +++ b/include/media/videobuf2-core.h > @@ -408,6 +408,9 @@ struct vb2_ops { > * @verify_planes_array: Verify that a given user space structure contains > * enough planes for the buffer. This is called > * for each dequeued buffer. > + * @init_buffer: given a &vb2_buffer initialize the extra data after > + * struct vb2_buffer. > + * For V4L2 this is a &struct vb2_v4l2_buffer. > * @fill_user_buffer: given a &vb2_buffer fill in the userspace structure. > * For V4L2 this is a &struct v4l2_buffer. > * @fill_vb2_buffer: given a userspace structure, fill in the &vb2_buffer. > @@ -418,6 +421,7 @@ struct vb2_ops { > */ > struct vb2_buf_ops { > int (*verify_planes_array)(struct vb2_buffer *vb, const void *pb); > + void (*init_buffer)(struct vb2_buffer *vb); > void (*fill_user_buffer)(struct vb2_buffer *vb, void *pb); > int (*fill_vb2_buffer)(struct vb2_buffer *vb, struct vb2_plane *planes); > void (*copy_timestamp)(struct vb2_buffer *vb, const void *pb); Thanks, Mauro