Re: [PATCH 1/1] v4l: async, fwnode: Improve module organisation

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

 



Hi Ezequiel,

On Tue, Mar 09, 2021 at 09:22:16AM -0300, Ezequiel Garcia wrote:
> On Tue, 2021-03-09 at 12:03 +0200, Sakari Ailus wrote:
> > Hi Ezequiel,
> > 
> > On Mon, Mar 08, 2021 at 04:01:58PM -0300, Ezequiel Garcia wrote:
> > > Hi Sakari,
> > > 
> > > Thanks a lot for the patch. I like where this is going.
> > 
> > Thanks for the review, too!
> > 
> > > 
> > > On Mon, 2021-03-08 at 12:02 +0200, Sakari Ailus wrote:
> > > > The V4L2 async framework is generally used with the V4L2 fwnode, which
> > > > also depends on the former. There is only one exception, the CAFE_CCIC
> > > > driver, which uses V4L2 async but does not need V4L2 fwnode.
> > > > 
> > > > At the same time there is a vast number of systems that need videodev
> > > > module, but have no use for v4l2-async that's now part of videodev.
> > > > 
> > > > In order to improve, build v4l2-async and v4l2-fwnode as a single module
> > > > called v4l2-async (the v4l2-async.c file is renamed as v4l2-async-core.c).
> > > > Also the menu item V4L2_FWNODE is renamed as V4L2_ASYNC.
> > > > 
> > > > This also moves the initialisation of the debufs entries for async subdevs
> > > > to loading of the v4l2-async module. The directory is named as
> > > > "v4l2-async".
> > > > 
> > > > Signed-off-by: Sakari Ailus <sakari.ailus@xxxxxxxxxxxxxxx>
> > > > ---
> > > > This goes on top of my recent async patches.
> > > > 
> > > >  drivers/media/i2c/Kconfig                     | 80 +++++++++----------
> > > >  drivers/media/i2c/ccs/Kconfig                 |  2 +-
> > > >  drivers/media/i2c/et8ek8/Kconfig              |  2 +-
> > > >  drivers/media/pci/intel/ipu3/Kconfig          |  2 +-
> > > >  drivers/media/platform/Kconfig                | 16 ++--
> > > >  drivers/media/platform/am437x/Kconfig         |  2 +-
> > > >  drivers/media/platform/atmel/Kconfig          |  4 +-
> > > >  drivers/media/platform/cadence/Kconfig        |  4 +-
> > > >  drivers/media/platform/davinci/Kconfig        |  2 +-
> > > >  drivers/media/platform/exynos4-is/Kconfig     |  4 +-
> > > >  drivers/media/platform/marvell-ccic/Kconfig   |  1 +
> > > >  drivers/media/platform/rcar-vin/Kconfig       |  4 +-
> > > >  .../media/platform/sunxi/sun4i-csi/Kconfig    |  2 +-
> > > >  .../media/platform/sunxi/sun6i-csi/Kconfig    |  2 +-
> > > >  drivers/media/platform/xilinx/Kconfig         |  2 +-
> > > >  drivers/media/v4l2-core/Kconfig               |  3 +-
> > > >  drivers/media/v4l2-core/Makefile              |  6 +-
> > > >  .../{v4l2-async.c => v4l2-async-core.c}       | 23 +++++-
> > > >  drivers/media/v4l2-core/v4l2-dev.c            |  5 --
> > > >  drivers/staging/media/imx/Kconfig             |  2 +-
> > > >  drivers/staging/media/tegra-video/Kconfig     |  2 +-
> > > >  21 files changed, 94 insertions(+), 76 deletions(-)
> > > >  rename drivers/media/v4l2-core/{v4l2-async.c => v4l2-async-core.c} (96%)
> > > > 
> > > [..]
> > > > diff --git a/drivers/media/v4l2-core/Kconfig b/drivers/media/v4l2-core/Kconfig
> > > > index bf49f83cb86f..26e12db0a4e8 100644
> > > > --- a/drivers/media/v4l2-core/Kconfig
> > > > +++ b/drivers/media/v4l2-core/Kconfig
> > > > @@ -62,13 +62,14 @@ config V4L2_FLASH_LED_CLASS
> > > >         tristate "V4L2 flash API for LED flash class devices"
> > > >         depends on VIDEO_V4L2 && VIDEO_V4L2_SUBDEV_API
> > > >         depends on LEDS_CLASS_FLASH
> > > > +       select V4L2_ASYNC
> > > >         help
> > > >           Say Y here to enable V4L2 flash API support for LED flash
> > > >           class drivers.
> > > >  
> > > >           When in doubt, say N.
> > > >  
> > > > -config V4L2_FWNODE
> > > > +config V4L2_ASYNC
> > > >         tristate
> > > >  
> > > 
> > > So we don't expect (or want) out-of-tree drivers to be able to use this.
> > > Is that correct?
> > 
> > Hmm. I somehow manage to miss how this is related to out-of-tree drivers.
> > 
> 
> As it is, the v4l2-async module is not user-selectable, because
> V4L2_ASYNC has no prompt (the symbol is non-visible).
> 
> For the user to be able to select the v4l2-async module,
> even if no driver is selecting it, it needs a prompt: 
> 
> config V4L2_ASYNC
> 	tristate "V4L2 asynchronous subdevice support"

Well, yes, you could do this in principle.

But this patch does not change this in any way, does it?

> 
> This is usually useful for out-of-tree drivers, AFAIK.

If someone needs this out-of-tree, they could also enable one of the
drivers that need v4l2-async in the kernel.

-- 
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