Hi Hans, Thanks for your patience and sharing your thoughts on this. > Subject: Re: [PATCH v4 00/12] Intel IPU3 ImgU patchset > > Hi Rajmohan, > > On 11/17/2017 03:58 AM, Mani, Rajmohan wrote: > > Hi Sakari and all, > > > >> -----Original Message----- > >> From: Zhi, Yong > >> Sent: Tuesday, October 17, 2017 8:47 PM > >> To: linux-media@xxxxxxxxxxxxxxx; sakari.ailus@xxxxxxxxxxxxxxx > >> Cc: Zheng, Jian Xu <jian.xu.zheng@xxxxxxxxx>; Mani, Rajmohan > >> <rajmohan.mani@xxxxxxxxx>; Toivonen, Tuukka > >> <tuukka.toivonen@xxxxxxxxx>; Hu, Jerry W <jerry.w.hu@xxxxxxxxx>; > >> arnd@xxxxxxxx; hch@xxxxxx; robin.murphy@xxxxxxx; iommu@lists.linux- > >> foundation.org; Zhi, Yong <yong.zhi@xxxxxxxxx> > >> Subject: [PATCH v4 00/12] Intel IPU3 ImgU patchset > >> > >> This patchset adds support for the Intel IPU3 (Image Processing Unit) > >> ImgU which is essentially a modern memory-to-memory ISP. It > >> implements raw Bayer to YUV image format conversion as well as a > >> large number of other pixel processing algorithms for improving the image > quality. > >> > >> Meta data formats are defined for image statistics (3A, i.e. > >> automatic white balance, exposure and focus, histogram and local area > >> contrast > >> enhancement) as well as for the pixel processing algorithm parameters. > >> The documentation for these formats is currently not included in the > >> patchset but will be added in a future version of this set. > >> > > > > Here is an update on the IPU3 documentation that we are currently working > on. > > > > Image processing in IPU3 relies on the following. > > > > 1) HW configuration to enable ISP and > > 2) setting customer specific 3A Tuning / Algorithm Parameters to achieve > desired image quality. > > > > We intend to provide documentation on ImgU driver programming interface > to help users of this driver to configure and enable ISP HW to meet their > needs. This documentation will include details on complete V4L2 Kernel driver > interface and IO-Control parameters, except for the ISP internal algorithm and > its parameters (which is Intel proprietary IP). > > > > We will also provide an user space library in binary form to help users of this > driver, to convert the public 3A tuning parameters to IPU3 algorithm > parameters. This tool will be released under NDA to the users of this driver. > > So I discussed this situation with Sakari in Prague during the ELCE. I am not > happy with adding a driver to the kernel that needs an NDA to be usable. I > can't agree to that. It's effectively the same as firmware that's only available > under an NDA and we wouldn't accept such drivers either. > Ack > There are a few options: > > 1) Document the ISP parameters and that format they are stored in allowing > for > open source implementations. While this is the ideal, I suspect that this is > a no-go for Intel. > Ack > 2) The driver can be used without using these ISP parameters and still achieve > 'OK' quality. I.e., it's usable for basic webcam usage under normal lighting > conditions. I'm not sure if this is possible at all, though. > This is something that we have tried and are able to do image capture with the default ISP parameters using ov5670 sensor. Additionally we had to set optimal values for the ov5670 sensor's exposure and gain settings. Please see if the following image looks to meet the 'OK' quality. git clone https://github.com/RajmohanMani/ipu3-misc.git ipu3-misc/ov5670.jpg is the image file. > 3) Make the library available without requiring an NDA. > We are also actively exploring this option to see if this can be done. > 4) Provide a non-NDA library (ideally open source) that achieves at minimum > the quality as described in 2: i.e. usable for basic webcam. > I see this is the same as option 3) + open sourcing the library. Open sourcing the library does not look to be an option. I will reconfirm this. > 5) Other solutions I didn't think of? > > I think 4 might be the best option, especially if it is open sourced and just uses > non-IP 3A algorithms. It could even be added to the v4l-utils git repo. > > A closed source non-NDA library might also work, but you will need to check > what Mauro thinks about that. I believe this is option 3) that you are referring here. Depending on the progress that we make on option 3), we can work on the next steps. > My problem is that such libraries tend to be > abandoned after a few years and then bit-rot sets in. An open-source solution > is much easier to maintain in the long term. > > Regards, > > Hans >