On Monday 08 August 2011 11:16:41 Hans Verkuil wrote: > On Friday, August 05, 2011 09:47:13 Guennadi Liakhovetski wrote: > > A possibility to preallocate and initialise buffers of different sizes > > in V4L2 is required for an efficient implementation of asnapshot mode. > > This patch adds two new ioctl()s: VIDIOC_CREATE_BUFS and > > VIDIOC_PREPARE_BUF and defines respective data structures. > > > > Signed-off-by: Guennadi Liakhovetski <g.liakhovetski@xxxxxx> > > --- > > > > v4: > > > > 1. CREATE_BUFS now takes an array of plane sizes and a fourcc code in its > > > > argument, instead of a frame format specification, including > > documentation update > > > > 2. documentation improvements, as suggested by Hans > > 3. increased reserved fields to 18, as suggested by Sakari > > > > Documentation/DocBook/media/v4l/io.xml | 17 ++ > > Documentation/DocBook/media/v4l/v4l2.xml | 2 + > > .../DocBook/media/v4l/vidioc-create-bufs.xml | 161 > > ++++++++++++++++++++ > > > .../DocBook/media/v4l/vidioc-prepare-buf.xml | 96 ++++++++++++ > > drivers/media/video/v4l2-compat-ioctl32.c | 6 + > > drivers/media/video/v4l2-ioctl.c | 26 +++ > > include/linux/videodev2.h | 18 +++ > > include/media/v4l2-ioctl.h | 2 + > > 8 files changed, 328 insertions(+), 0 deletions(-) > > create mode 100644 > > Documentation/DocBook/media/v4l/vidioc-create-bufs.xml create mode > > 100644 Documentation/DocBook/media/v4l/vidioc-prepare-buf.xml > > <snip> > > > diff --git a/include/linux/videodev2.h b/include/linux/videodev2.h > > index fca24cc..3cd0cb3 100644 > > --- a/include/linux/videodev2.h > > +++ b/include/linux/videodev2.h > > @@ -653,6 +653,9 @@ struct v4l2_buffer { > > > > #define V4L2_BUF_FLAG_ERROR 0x0040 > > #define V4L2_BUF_FLAG_TIMECODE 0x0100 /* timecode field is valid */ > > #define V4L2_BUF_FLAG_INPUT 0x0200 /* input field is valid */ > > > > +/* Cache handling flags */ > > +#define V4L2_BUF_FLAG_NO_CACHE_INVALIDATE 0x0400 > > +#define V4L2_BUF_FLAG_NO_CACHE_CLEAN 0x0800 > > > > /* > > > > * O V E R L A Y P R E V I E W > > > > @@ -2092,6 +2095,18 @@ struct v4l2_dbg_chip_ident { > > > > __u32 revision; /* chip revision, chip specific */ > > > > } __attribute__ ((packed)); > > > > +/* VIDIOC_CREATE_BUFS */ > > +struct v4l2_create_buffers { > > + __u32 index; /* output: buffers index...index + count - 1 have been > > created */ > > > + __u32 count; > > + __u32 type; > > + __u32 memory; > > + __u32 fourcc; > > + __u32 num_planes; > > + __u32 sizes[VIDEO_MAX_PLANES]; > > + __u32 reserved[18]; > > +}; > > I know you are going to hate me for this, but I've changed my mind: I think > this should use a struct v4l2_format after all. > > This change of heart came out of discussions during the V4L2 brainstorm > meeting last week. The only way to be sure the buffers are allocated > optimally is if the driver has all the information. The easiest way to do > that is by passing struct v4l2_format. This is also consistent with > REQBUFS since that uses the information from the currently selected format > (i.e. what you get back from VIDIOC_G_FMT). > > There can be subtle behaviors such as allocating from different memory back > based on the fourcc and the size of the image. > > One reason why I liked passing sizes directly is that it allows the caller > to ask for more memory than is strictly necessary. > > However, while brainstorming last week the suggestion was made that there > is no reason why the user can't set the sizeimage field in > v4l2_pix_format(_mplane) to something higher. The S/TRY_FMT spec explicitly > mentions that the sizeimage field is set by the driver, but for the new > CREATEBUFS ioctl no such limitation has to be placed. The only thing > necessary is to ensure that sizeimage is not too small (and you probably > want some sanity check against crazy values as well). We need to decide on a policy here. What should be the maximum allowable size for MMAP buffers ? How do we restrict the requested image size so that application won't be allowed to starve the system by requesting memory for 1GP images ? > This way the decision on how to allocate memory is the same between REQBUFS > and CREATEBUFS (i.e. both use v4l2_format information), but there is no > need for a union as we had in the initial proposal since apps can set the > sizeimage to something larger than strictly necessary (or just leave it to > 0 to get the smallest size). -- Regards, Laurent Pinchart -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html