Re: Help Regarding I2C Driver...

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

 



On Mon, Mar 23, 2009 at 09:54:50AM +0530, Uma Kanta Patro wrote:
>                 This is Uma Kanta, seeking some help regarding the I2C
> driver development on ARM Linux 2.6.19 platform.

This version is ancient, you should consider updating to something more
recent.

> I referred the second part of i2C driver articles in Linux Journal by Greg
> Kroah. As well as the book Essential Linux Device Drivers.
> I have to make I2C driver for a RTC (DS1340) and a camera module (Omnivision
> OVM7670).
> I could be able to make a chip driver. Unfortunately I was unable to insert
> the core driver ?i2c_core? internally. So I inserted the i2c_core.ko and my
> own driver i2c_test.ko.
> Now both drivers are getting inserted fine but the problem exists is:
> In my init I am adding my i2c driver structure by using ?i2c_add_driver()?,
> and my i2c driver structure named ?i2c_test_driver?, whose declaration is as
> follows:
> 
> struct i2c_driver i2c_test_driver = {
>                 .driver = {
>                                 .name   = "i2c_test",
>                 },
>                 .id = I2C_DRIVERID_OVCAMCHIP,            /* OmniVision CMOS
> image sens.            *//* defined in include/linux/i2c-id.h */
>                 .attach_adapter               = i2c_test_attach_adapter,
>                 .detach_client   = i2c_test_detach_client,
> };

attach_adapter and friends are legacy callbacks, you should not use them
in new drivers. Did you read Documentation/i2c/writing-clients?

> So here ?list_for_each(item,&adapters)? returns FALSE for me. So my attach
> adapter function, ?i2c_test_attach_adapter()? is not getting called.

Probing should be done by setting i2c_board_info from your board support
code - also described in Documentation/i2c/writing-clients.

> So I searched where the entry ?adapters? is getting a tail added in the
> function ?i2c_add_adapter()? So the function ?i2c_add_adapter ()? will be
> called by any client driver(as mentioned in comment?).
> I tried by all ?*.ko? files in KERN_SRC/drivers/i2c/algos/ but no effect.
> So now to get the full functional I2C chip driver do I need to write a
> client driver for it?

You're digging too much through the core code. It works well for others,
so debugging this part is not the first thing you should consider. Best
thing is probably to grab an existing driver and see how it does the
job.

Daniel
--
To unsubscribe from this list: send the line "unsubscribe linux-i2c" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux GPIO]     [Linux SPI]     [Linux Hardward Monitoring]     [LM Sensors]     [Linux USB Devel]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux