I2C dummy adapter driver ?

Sylwester Nawrocki s.nawrocki at samsung.com
Fri Mar 7 08:49:32 EST 2014


On 05/03/14 02:15, Mark Brown wrote:
> On Tue, Mar 04, 2014 at 12:38:28PM +0100, Sylwester Nawrocki wrote:
>> On 28/02/14 07:07, Mark Brown wrote:
>>> On Fri, Feb 21, 2014 at 12:45:21PM +0100, Sylwester Nawrocki wrote:
> 
>>>> The I2C bus driver with empty i2c_algorithm.master_xfer() helps WRT to
>>>> using standard DT binding and v4l2_subdev interface.
> 
>>> Wouldn't a platform device do just as well here if there's no actual
>>> control?
> 
>> Then the I2C client devices would have to be instantiated manually, 
>> I think it's more trouble.
> 
> I2C is not that much more enumerable than platform bus, I don't see the
> difference here?  To the extent I2C is enumerable a dummy adaptor isn't
> going to support that.

Yes, it won't be enumerable, I just meant allocating client devices 
would need to be taken care of, rather that having this handled entirely 
by, e.g. i2c-core. 

>> I could as well create custom I2C client drivers per ISP, but then the 
>> I2C devices would have to be represented somehow in DT, to pass stuff 
>> like voltage regulators and GPIOs. Anyway, it's not something could be 
>> done in mainline.
> 
> Why not?

Well, my concern was that existing sub-device drivers would need to be
extended to handle other bus types, like the platform bus.

And since that very same device could be controlled by the host CPU or
not, it just depends what host interface/SoC it is linked to, such
a complication may not be justified.  It's like introducing bridge/host 
details to the client drivers. In general the sub-devices should be
host-agnostic.

>> Even if there is no actual I2C communication on the host CPU side, the 
>> power up/down sequence is handled there. The intention is to keep this 
>> common per an I2C client, regardless of whether I2C communication is 
>> done by firmware or the host the CPU.
> 
> The way you're talking it sounds like your code is very hard coded to
> use I2C here.  What happens if someone uses SPI or some other bus to
> control an ISP?

The other busses, like SPI, are also handled the V4L2 subdev in 
a standard way.  The host just need to be aware on what control bus 
a subdev is located on, to get hold of it.

Let me add that for image sensors I2C is used as a control bus in 
majority of cases.  An I2C-compatible (CCI) bus is specified as 
a control bus by the MIPI CSI-2 specification. With newer version 
of the standard we may need to create a MIPI CSI (control) bus.



More information about the linux-arm-kernel mailing list