Re: [RFC v2] [media] v4l2: add V4L2 pixel format array and helper functions

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Em Thu, 28 Aug 2014 18:40:53 +0200
Hans Verkuil <hverkuil@xxxxxxxxx> escreveu:

> On 08/28/2014 06:25 PM, Laurent Pinchart wrote:
> > Hi Philipp,
> > 
> > On Thursday 28 August 2014 18:09:35 Philipp Zabel wrote:
> >> Am Donnerstag, den 28.08.2014, 14:24 +0200 schrieb Laurent Pinchart:
> >>>> A driver could then do the following:
> >>>>
> >>>> static struct v4l2_pixfmt_info driver_formats[] = {
> >>>>
> >>>> 	{ .pixelformat = V4L2_PIX_FMT_YUYV },
> >>>> 	{ .pixelformat = V4L2_PIX_FMT_YUV420 },
> >>>>
> >>>> };
> >>>>
> >>>> int driver_probe(...)
> >>>> {
> >>>>
> >>>> 	...
> >>>> 	v4l2_init_pixfmt_array(driver_formats,
> >>>> 	
> >>>> 			ARRAY_SIZE(driver_formats));
> >>>> 	
> >>>> 	...
> >>>>
> >>>> }
> >>>
> >>> Good question. This option consumes more memory, and prevents the driver-
> >>> specific format info arrays to be const, which bothers me a bit.
> >>
> >> Also, this wouldn't help drivers that don't want to take these
> >> additional steps, which probably includes a lot of camera drivers with
> >> only a few formats.
> >>
> >>> On the other hand it allows drivers to override some of the default
> >>> values for odd cases.
> >>
> >> Hm, but those cases don't have to use the v4l2_pixfmt_info at all.
> >>
> >>> I won't nack this approach, but I'm wondering whether a better
> >>> solution wouldn't be possible. Hans, Mauro, Guennadi, any opinion ?
> >>
> >> We could keep the global v4l2_pixfmt_info array sorted by fourcc value
> >> and do a binary search (would have to be kept in mind when adding new
> >> formats)
> > 
> > I like that option, provided we can ensure that the array is sorted. This can 
> > get a bit tricky, and Hans might wear his "don't over-optimize" hat :-)

The big issue is that, afaikt, there's no way to make gcc to order it,
so the order would need to be manually ensured. This is challenging, and
makes the review process complex if done right.

I really don't see any gain on applying such patch. If the concern is
just about properly naming the pixel formats, it is a way easier to use
some defines for the names, and use the defines. Btw, that's how we solved
this issue at rc core:
	http://git.linuxtv.org/cgit.cgi/media_tree.git/tree/include/media/rc-map.h

Also, that means a less footprint for tiny Kernels.

> Well, for small sets of data (which this is) a binary search may well be
> slower than a simple search. So yes, you should do some performance tests
> before going with the more complex option.

with 128 pixformats, a binary search takes 8 ifs against 128. So, it
should be faster.

Yet, even on a very slow machine, seeking for 128 formats is still
likely fast enough to not affect performance of a media application.

> By placing the commonly used pixel formats at the beginning of the list I
> suspect a simple search is the fastest lookup method, and very easy to
> implement as well.

IMHO, we shouldn't apply this approach, as we're just growing the
Kernel size without any real benefit.

Regards,
Mauro
--
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




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux