Re: OV5693 Kconfig missing a select VIDEO_V4L2_SUBDEV_API ?

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

 



Hi Hans,

On Wed, Jun 14, 2023 at 06:50:14PM +0200, Hans de Goede wrote:
> Hi Sakari,
> 
> On 6/14/23 18:05, sakari.ailus@xxxxxxxxxxxxxxx wrote:
> > Hi Hans,
> > 
> > On Wed, Jun 14, 2023 at 05:47:01PM +0200, Hans de Goede wrote:
> >> Hi All,
> >>
> >> The ov5693 driver uses v4l2_subdev_get_try_crop() /
> >> v4l2_subdev_get_try_format() both of which are
> >> only defined if CONFIG_VIDEO_V4L2_SUBDEV_API=y .
> >>
> >> Yet it does not do select VIDEO_V4L2_SUBDEV_API
> >> in its Kconfig bits ?
> >>
> >> Note I've not seen any build errors because of this,
> >> I guess we somehow end up getting away with this...
> >>
> >> But still I think the select should be added ?
> > 
> > I agree.
> > 
> > The reason there haven't been compile failures is that there's a vast
> > number of sensor drivers that all select this so for a failure you'd need
> > to select this one but none of the others.
> > 
> > I can send a fix.
> 
> Also see my follow-up email. If we're going to fix this
> we really should fix it properly. As mentioned in
> my folow-up email an intermediate Kconfig option
> might be best.
> 
> E.g. doing:
> 
> grep -l v4l2_async_register_subdev drivers/media/i2c/*.c
> 
> And comparing that to Kconfig finds the following Kconfig
> entries lacking a select V4L2_FWNODE / select V4l2_ASYNC
> 
> VIDEO_IMX208
> VIDEO_IMX258
> VIDEO_IMX274
> VIDEO_IMX319
> VIDEO_IMX355
> VIDEO_OV6650
> VIDEO_OV7740
> VIDEO_OV9640
> VIDEO_OV9650
> 
> and I stopped checking after the ov* drivers since I think
> the above list makes my point.

Yeah, sometimes difficult to find errors get repeated. Luckily it's "just"
a compilation problem.

Using V4L2 fwnode and V4L2 sub-device APIs are still unrelated as such
although in practice they do often happen together. There are still quite a
few sensor drivers that don't need both of them. Some can be compiled with
VIDEO_V4L2_SUBDEV_API disabled, too, but I'm not sure how useful that
really is. The rest are probably not usable outside a very specific scope,
such as I²C async matching used by a handful of receiver drivers (none use
MC, thus no sub-device API either).

Perhaps we could group these in two classes where the common class has
V4L2_FWNODE and VIDEO_V4L2_SUBDEV_API selected? I'm not sure having an
intermediate, somewhat obscure, option would be helpful.

Also cc Hans and Laurent.

-- 
Regards,

Sakari Ailus



[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