Re: [RFC v2 3/3] dt: bindings: Add a binding for referencing EEPROM from camera sensors

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

 



Hi Daniel,

On Mon, May 29, 2017 at 02:39:01PM +0200, Daniel Mack wrote:
> On 05/29/2017 02:20 PM, Sakari Ailus wrote:
> > On Mon, May 08, 2017 at 12:24:18PM -0500, Rob Herring wrote:
> >> On Fri, May 05, 2017 at 11:48:30AM +0300, Sakari Ailus wrote:
> >>> Many camera sensor devices contain EEPROM chips that describe the
> >>> properties of a given unit --- the data is specific to a given unit can
> >>> thus is not stored e.g. in user space or the driver.
> >>>
> >>> Some sensors embed the EEPROM chip and it can be accessed through the
> >>> sensor's I2C interface. This property is to be used for devices where the
> >>> EEPROM chip is accessed through a different I2C address than the sensor.
> >>
> >> Different I2C address or bus? We already have i2c bindings for sub 
> >> devices downstream of another I2C device. Either the upstream device 
> >> passes thru the I2C transactions or itself is an I2C controller with a 
> >> separate downstream bus. For those cases the EEPROM should be a child 
> >> node. A phandle only makes sense if you have the sensor and eeprom 
> >> connected to 2 entirely separate host buses.
> > 
> > Right. It's a different address but located in the same package with the
> > module, just like the lens. I should have actually said "module", not the
> > "sensor".
> > 
> > The EEPROM integration to the module is done by the module vendor, but it's
> > entirely possible to have another module vendor to use the sensor but not
> > add an EEPROM or use a different EEPROM. It is also possible that the EEPROM
> > is on the same silicon with the sensor, then it's always guaranteed to be
> > there.
> > 
> > The bottom line is still that a sensor is simply one of the component in a
> > camera module; the rest of the module (lens, eeprom etc.) is not defined by
> > the sensor, the parts are rather picked by the module vendor. Yet the sensor
> > is a central piece in a module: it's always guaranteed to be there or it's
> > not a camera module.
> 
> I agree, yes. I think the only way to solve this is to have a generic
> EEPROM API that allows the camera sensor to read data from it. If

We have one already, and it's defined in Documentation/misc-devices/eeprom .

> another vendor uses a different type of EEPROM, the sensor driver would
> remain the same, as it only reads data from the storage behind the
> phandle, not caring about the details.
> 
> Same goes for the lens driver, and after thinking about it for awhile,
> I'd say it makes most sense to allow referencing a v4l2_subdev device
> through a phandle from another v4l2_subdev, and then offload certain
> commands such as V4L2_CID_FOCUS_ABSOLUTE to the device that does the
> actual work. Opinions?

There are different kinds of lens systems and I don't think the sensor
drivers should be aware of them. The current approach is that the lens is a
separate sub-device --- the intent of the patchset I posted was to document
how the information on the related lens and eeprom components is conveyed to
the software. There's one such driver in the mainline kernel, ad5820.

Unfortunately we don't right now have a good user space interface for
telling which sensor a lens device is related to. The struct
media_entity_desc does have a group_id field for grouping the sub-devices
but that's hardly a good way to describe this.

-- 
Sakari Ailus
e-mail: sakari.ailus@xxxxxx	XMPP: sailus@xxxxxxxxxxxxxx



[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