On 08/28/2014 07:32 PM, Hans Verkuil wrote: > On 08/28/2014 07:18 PM, Mauro Carvalho Chehab wrote: >> 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. > > It's not just the names, also the bit depth etc. Most drivers need that information > and having it in a central place simplifies driver design. Yes, it slightly > increases the amount of memory, but that is insignificant compared to the huge > amount of memory necessary for video buffers. And reducing driver complexity is > always good since that has always been the main problem with drivers, not memory > or code performance. I just want to add that we should try out any core solution with an existing driver (e.g. saa7134) to see if whatever solution we come up with actually makes drivers less complex. The saa7134 is from what I've seen fairly representative of most in that is has additional fields besides the name, fourcc and depth that are driver specific. So how will that be handled... Regards, Hans -- 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