Re: [PATCH v4 14/36] [media] v4l2-mc: add a function to inherit controls from a pipeline
From: Mauro Carvalho Chehab
Date: Mon Mar 20 2017 - 11:41:28 EST
Em Mon, 20 Mar 2017 14:24:25 +0100
Hans Verkuil <hverkuil@xxxxxxxxx> escreveu:
> On 03/14/2017 11:21 AM, Mauro Carvalho Chehab wrote:
> > Em Tue, 14 Mar 2017 08:55:36 +0100
> > Hans Verkuil <hverkuil@xxxxxxxxx> escreveu:
> >
> >> On 03/14/2017 04:45 AM, Mauro Carvalho Chehab wrote:
> >>> Hi Sakari,
> >>>
> >> We're all very driver-development-driven, and userspace gets very little
> >> attention in general. So before just throwing in the towel we should take
> >> a good look at the reasons why there has been little or no development: is
> >> it because of fundamental design defects, or because nobody paid attention
> >> to it?
> >
> > No. We should look it the other way: basically, there are patches
> > for i.MX6 driver that sends control from videonode to subdevs.
> >
> > If we nack apply it, who will write the userspace plugin? When
> > such change will be merged upstream?
> >
> > If we don't have answers to any of the above questions, we should not
> > nack it.
> >
> > That's said, that doesn't prevent merging a libv4l plugin if/when
> > someone can find time/interest to develop it.
>
> I don't think this control inheritance patch will magically prevent you
> from needed a plugin.
Yeah, it is not just control inheritance. The driver needs to work
without subdev API, e. g. mbus settings should also be done via the
video devnode.
Btw, Sakari made a good point on IRC: what happens if some app
try to change the pipeline or subdev settings while another
application is using the device? The driver should block such
changes, maybe using the V4L2 priority mechanism.
> This is literally the first time we have to cater to a cheap devkit. We
> were always aware of this issue, but nobody really needed it.
That's true. Now that we have a real need for that, we need to
provide a solution.
> > I'd say that we should not care anymore on providing a solution for
> > generic applications to run on boards like OMAP3[1]. For hardware that
> > are currently available that have Kernel driver and boards developed
> > to be used as "cheap hobbyist devkit", I'd say we should implement
> > a Kernel solution that would allow them to be used without subdev
> > API, e. g. having all ioctls needed by generic applications to work
> > functional, after some external application sets the pipeline.
>
> I liked Russell's idea of having the DT set up an initial video path.
> This would (probably) make it much easier to provide a generic plugin since
> there is already an initial valid path when the driver is loaded, and it
> doesn't require custom code in the driver since this is left to the DT
> which really knows about the HW.
Setting the device via DT indeed makes easier (either for a kernel
or userspace solution), but things like resolution changes should
be possible without needing to change DT.
Also, as MC and subdev changes should be blocked while a V4L2 app
is using the device, using a mechanism like calling VIDIOC_S_PRIORITY
ioctl via the V4l2 interface, Kernel will require changes, anyway.
My suggestion is to touch on one driver to make it work with a
generic application. As we currently have efforts and needs for
the i.MX6 to do it, I'd say that the best would be to make it
work on such driver. Once the work is done, we can see if the
approach taken there would work at libv4l or not.
In parallel, someone has to fix libv4l for it to be default on
applications like gstreamer, e. g. adding support for DMABUF
and fixing other issues that are preventing it to be used by
default.
Nicolas,
Why libv4l is currently disabled at gstreamer's default settings?
> > [1] Yet, I might eventually do that for fun, an OMAP3 board with tvp5150
> > just arrived here last week. It would be nice to have xawtv3 running on it :-)
> > So, if I have a lot of spare time (with is very unlikely), I might eventually
> > do something for it to work.
> >
> >> I know it took me a very long time before I had a working omap3.
> >
> > My first OMAP3 board with working V4L2 source just arrived last week :-)
> >
> >> So I am not at all surprised that little progress has been made.
> >
> > I'm not surprised, but I'm disappointed, as I tried to push toward a
> > solution for this problem since when we had our initial meetings about
> > it.
>
> So many things to do, so little time. Sounds corny, but really, that's what
> this is all about. There were always (and frankly, still are) more important
> things that needed to be done.
What's most important for some developer may not be so important for
another developer.
My understanding here is that there are developers wanting/needing
to have standard V4L2 apps support for (some) i.MX6 devices. Those are
the ones that may/will allocate some time for it to happen.
Thanks,
Mauro