Hi Hans, On Monday 08 August 2011 14:40:27 Hans Verkuil wrote: > On Monday, August 08, 2011 13:40:23 Laurent Pinchart wrote: > > 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 ? > > Either just a arbitrary cap like 1 GB (mainly to prevent any weird > calculation problems around the 2 GB (signedness) and 4 GB (wrap-around) > boundaries), or something like 3 or 4 times the minimum buffer size. > > I'm in favor of enforcing a 1 GB cap in vb2 and letting drivers enforce a > policy of their own if that makes sense for them. Wouldn't that be a security issue ? Any application with permissions to access the video device could DoS the system. > I don't really see a problem with requesting large amounts of memory. What > constitutes 'large' is not something the kernel knows, that's dependent on > the use case. -- 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