2.6.34的i2c子系统基本不再区分legacy model和standard drivermodel的驱动了,现在可以说只有一种。
现在i2c设备驱动的编写方式可以分为两大类(我自己分的,不是权威分法),一类是不注册i2c_driver。
因为和i2c设备的通信不需要i2c_driver,这仅仅是一个辅助性的结构体,
和i2c设备的通信只需要i2c_client就可以了。
直接获得i2c_client的方法就是使用i2c_new_device()和i2c_new_probed_device()。也就是枚举产生i2c_client的方法2。
第二类方式就是需要编写并注册i2c_driver了。这种方法的思想是分别注册i2c_client和i2c_driver,
然后让内核的驱动模型将i2c_client和i2c_driver进行匹配,调用i2c_driver的probe成员函数。
i2c_driver必须初始化的成员有:
int (*probe)(struct i2c_client *, const struct i2c_device_id *); int (*remove)(struct i2c_client *);
const struct i2c_device_id *id_table;//支持的i2c_client名字列表。
其他成员看具体情况而定。
建立i2c_client的方法有5种s,除去方法2,其他方法都和本类驱动配合使用。
能够和i2c_device_id中的名字匹配的i2c_client注册以后,i2c_driver的probe函数会被调用。用户可以在这个函数中为设备申请私有数据结构。