Hello, On 08/16/2011 05:30 PM, Mauro Carvalho Chehab wrote: > Em 16-08-2011 01:57, Laurent Pinchart escreveu: >> Hi Mauro, > >>>> My point is that the ISP driver developer can't know in advance which >>>> sensor will be used systems that don't exist yet. >>> >>> As far as such hardware is projected, someone will know. It is a simple >>> trivial patch to associate a new hardware with a hardware profile at the >>> platform data. My question here would be whether we want to have a kernel patch fixing up the configuration for each H/W case or rather a user space script that will set up a data processing chain ? >> >> Platform data must contain hardware descriptions only, not policies. This is >> even clearer now that ARM is moving away from board code to the Device Tree. > > Again, a cell phone with one frontal camera and one hear camera has two > sensor inputs only. This is not a "policy". It is a hardware constraint. There is a policy because you have to tweak the device configuration for a specific board and sensor. It seems impossible to have fully functional drivers in the mainline with such a simplistic approach. > The driver should allow setting the pipeline for both sensors via S_INPUT, > otherwise a V4L2 only userspace application won't work. > > It is as simple as that. > >>> Also, on most cases, probing a sensor is as trivial as reading a sensor >>> ID during device probe. This applies, for example, for all Omnivision >>> sensors. >>> >>> We do things like that all the times for PC world, as nobody knows what >>> webcam someone would plug on his PC. >> >> Sorry, but that's not related. You simply can't decide in an embedded ISP >> driver how to deal with sensor controls, as the system will be used in a too >> wide variety of applications and hardware configurations. All controls need to >> be exposed, period. > > We're not talking about controls. We're talking about providing the needed > V4L2 support to allow an userspace application to access the hardware > sensor. Which involves the controls as well. > >>>>> I never saw an embedded hardware that allows physically changing the >>>>> sensor. >>>> >>>> Beagleboard + pluggable sensor board. >>> >>> Development systems like beagleboard, pandaboard, Exynos SMDK, etc, aren't >>> embeeded hardware. They're development kits. >> >> People create end-user products based on those kits. That make them first- >> class embedded hardware like any other. > > No doubt they should be supported, but it doesn't make sense to create tons > of input pipelines to be used for S_INPUT for each different type of possible > sensor. Somehow, userspace needs to tell what's the sensor that he attached > to the hardware, or the driver should suport auto-detecting it. > > In other words, I see 2 options for that: > 1) add hardware auto-detection at the sensor logic. At driver probe, > try to probe all sensors, if it is a hardware development kit; Isn't it better to let the application discover what type of sensor the kernel exposes and apply a pre-defined ISP configuration for it ? If I am not mistaken, this is what happens currently in OMAP3 ISP systems. Should the base parameters for the I2C client registration be taken from platform_data/the flatted device tree. > 2) add one new parameter at the driver: "sensors". If the hardware > is one of those kits, this parameter will allow the developer to specify > the used sensors. It is the same logic as we do with userspace TV and > grabber cards without eeprom or any other way to auto-detect the hardware. Sorry, this does not look sane to me.. What is the driver supposed to do with such a list of sensors ? Hard code the pipeline configurations for them ? > >>> I don't mind if, for those kits the developer that is playing with it has to >>> pass a mode parameter and/or run some open harware-aware small application >>> that makes the driver to select the sensor type he is using, but, if the >>> hardware is, instead, a N9 or a Galaxy Tab (or whatever embedded hardware), >>> the driver should expose just the sensors that exists on such hardware. It >>> shouldn't be ever allowed to change it on userspace, using whatever API on >>> those hardware. >> >> Who talked about changing sensors from userspace on those systems ? Platform >> data (regardless of whether it comes from board code, device tree, or >> something else) will contain a hardware description, and the kernel will >> create the right devices and load the right drivers. The issue we're >> discussing is how to expose controls for those devices to userspace, and that >> needs to be done through subdev nodes. > > The issue that is under discussion is the removal of S_INPUT from the samsung > driver, and the comments at the patches that talks about removing V4L2 API > support in favor of using a MC-only API for some fundamental things. > > For example, with a patch like this one, only one sensor will be supported > without the MC API (either the front or back sensor on a multi-sensor camera): > http://git.infradead.org/users/kmpark/linux-2.6-samsung/commit/47751733a322a241927f9238b8ab1441389c9c41 That's not true. There are 3 or 4 host interfaces on those SoC's. Each exports a capture video node. After the above patch the front and rear camera are available on separate video nodes on input 0, rather than on a single video node and distinct inputs. I don't really get why there is so much noise about so meaningless detail. I decided to use MC API because I had to add support for MIPI-CSI bus. This API seemed a natural choice as there had to be added an extra subdevice between sensor and the host - the mipi csi receiver subdev. By using the subdev user space API the use cases like this one can be easily supported: | sensor subdev | -> | mipi-csi subdev | -x-> | FIMC0 | -> /dev/video? => encoder | x-> | FIMC1 (scaler) | -> /dev/video? => preview To lower the main system bus bandwidth by attaching a sensor to both host interfaces directly through the camera data buses. The mipi-csi subdev and the sensor need to be configured separately from the host if, otherwise there is a conflict which /dev/video? is to control the subdevs. Let's try to use S_INPUT here, assuming that both subdev are set up by the /dev/video? driver. The questions that need to be answered first : a) at which v4l2 entity to register the subdevs ? b) how to arbiter the subdev access from multiple /dev/video? ? ... | sensor1 subdev | -> | mipi-csi subdev | -x-> | FIMC0 | -> /dev/video? | | sensor2 subdev | -------------->---------x The problem with S_INPUT is that it requires adding/removing elements in the pipeline which belongs to the media device domain. > > Look at the comment on this patch also: > http://git.infradead.org/users/kmpark/linux-2.6-samsung/commit/c6fb462c38be60a45d16a29a9e56c886ee0aa08c > > What is called "API compatibility mode" is not clear, but it transmitted > me that the idea is to expose the controls only via subnodes. The "API compatibility mode" is a simple boolean which tells whether: a) the sensor and the mipi csi receiver are configured internally in the kernel from the capture video node level (an alternative is to do it for each subdev in user space); b) the sensor controls are inherited by the video node or not. I wish I could find better ways than a sysfs entry to handle the above issues. Most likely I'll remove all redundant V4L2 ioctls from the driver, like VIDIOC_CROPCAP, VIDIOC_[S/G]_CROP, and all the subdevs configuration from the driver. Then there is no any compatibility issue, only single API - subdev user-space API!... OK, now I'm hiding:) ... > > Those are the rationale for those discussions: V4L2 API is not being deprecated > in favor of MC API, e. g. controls shouldn't be hidden from the V4L2 API without > a good reason. Indeed. One remark though - I really haven't restricted the S_INPUT call just for fun of it. :-) Is that really a problem that the sensors have been distributed across multiple video nodes ? >>>>>> Even if you did, fine image quality tuning requires accessing pretty >>>>>> much all controls individually anyway. >>>>> >>>>> The same is also true for non-embedded hardware. The only situation >>>>> where V4L2 API is not enough is when there are two controls of the same >>>>> type active. For example, 2 active volume controls, one at the audio >>>>> demod, and another at the bridge. There may have some cases where you >>>>> can do the same thing at the sensor or at a DSP block. This is where MC >>>>> API gives an improvement, by allowing changing both, instead of just >>>>> one of the controls. >>>> >>>> To be precise it's the V4L2 subdev userspace API that allows that, not >>>> the MC API. >>>> >>>>>>>> This is a hack...sorry, just joking ;-) Seriously, I think the >>>>>>>> situation with the userspace subdevs is a bit different. Because with >>>>>>>> one API we directly expose some functionality for applications, with >>>>>>>> other we code it in the kernel, to make the devices appear uniform at >>>>>>>> user space. >>>>>>> >>>>>>> Not sure if I understood you. V4L2 export drivers functionality to >>>>>>> userspace in an uniform way. MC api is for special applications that >>>>>>> might need to access some internal functions on embedded devices. >>>>>>> >>>>>>> Of course, there are some cases where it doesn't make sense to export >>>>>>> a subdev control via V4L2 API. >>>>>>> >>>>>>>>>> Also, the sensor subdev can be configured in the video node driver >>>>>>>>>> as well as through the subdev device node. Both APIs can do the >>>>>>>>>> same thing but in order to let the subdev API work as expected the >>>>>>>>>> video node driver must be forbidden to configure the subdev. >>>>>>>>> >>>>>>>>> Why? For the sensor, a V4L2 API call will look just like a bridge >>>>>>>>> driver call. The subdev will need a mutex anyway, as two MC >>>>>>>>> applications may be opening it simultaneously. I can't see why it >>>>>>>>> should forbid changing the control from the bridge driver call. >>>>>>>> >>>>>>>> Please do not forget there might be more than one subdev to configure >>>>>>>> and that the bridge itself is also a subdev (which exposes a scaler >>>>>>>> interface, for instance). A situation pretty much like in Figure 4.4 >>>>>>>> [1] (after the scaler there is also a video node to configure, but we >>>>>>>> may assume that pixel resolution at the scaler pad 1 is same as at >>>>>>>> the video node). Assuming the format and crop configuration flow is >>>>>>>> from sensor to host scaler direction, if we have tried to configure >>>>>>>> _all_ subdevs when the last stage of the pipeline is configured >>>>>>>> (i.e. video node) the whole scaler and crop/composition >>>>>>>> configuration we have been destroyed at that time. And there is more >>>>>>>> to configure than >>>>>>>> VIDIOC_S_FMT can do. >>>>>>> >>>>>>> Think from users perspective: all user wants is to see a video of a >>>>>>> given resolution. S_FMT (and a few other VIDIOC_* calls) have >>>>>>> everything that the user wants: the desired resolution, framerate and >>>>>>> format. >>>>>>> >>>>>>> Specialized applications indeed need more, in order to get the best >>>>>>> images for certain types of usages. So, MC is there. >>>>>>> >>>>>>> Such applications will probably need to know exactly what's the >>>>>>> sensor, what are their bugs, how it is connected, what are the DSP >>>>>>> blocks in the patch, how the DSP algorithms are implemented, etc, in >>>>>>> order to obtain the the perfect image. >>>>>>> >>>>>>> Even on embedded devices like smartphones and tablets, I predict that >>>>>>> both types of applications will be developed and used: people may use >>>>>>> a generic application like flash player, and an specialized >>>>>>> application provided by the manufacturer. Users can even develop >>>>>>> their own applications generic apps using V4L2 directly, at the >>>>>>> devices that allow that. >>>>>>> >>>>>>> As I said before: both application types are welcome. We just need to >>>>>>> warrant that a pure V4L application will work reasonably well. >>>>>> >>>>>> That's why we have libv4l. The driver simply doesn't receive enough >>>>>> information to configure the hardware correctly from the VIDIOC_* >>>>>> calls. And as mentioned above, 3A algorithms, required by "simple" >>>>>> V4L2 applications, need to be implemented in userspace anyway. >>>>> >>>>> It is OK to improve users experience via libv4l. What I'm saying is that >>>>> it is NOT OK to remove V4L2 API support from the driver, forcing users >>>>> to use some hardware plugin at libv4l. >>>> >>>> Let me be clear on this. I'm *NOT* advocating removing V4L2 API support >>>> from any driver (well, on the drivers I can currently think of, if you >>>> show me a wifi driver that implements a V4L2 interface I might change my >>>> mind :-)). >>> >>> This thread is all about a patch series partially removing V4L2 API >>> support. >> >> Because that specific part of the API doesn't make sense for this use case. >> You wouldn't object to removing S_INPUT support from a video output driver, as >> it wouldn't make sense either. > > A device with two sensors input where just one node can be switched to use > either input is a typical case where S_INPUT needs to be provided. For simple webcams that V4L2 is mostly used for, that's true. -- Regards, Sylwester -- 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