我的理念:簡單實用即可,不要搞一堆源碼出來,結果讓人看了以后還不知道怎么用,看我的:
1、在arch/arm/mach-xxx/ 自己的平台文件里添加i2c信息,美其名曰:i2c_board_info
例如:
static struct i2c_board_info __initdata xxxi2c_board_info[] = {
{
I2C_BOARD_INFO("abcd1", 0x20), /* 字符串要與后面的匹配,0x20是從設備地址 */
.platform_data = 0,
},
{
I2C_BOARD_INFO("abcd2", 0x21),
.platform_data = 0,
},
};
然后調用i2c_register_board_info(1, xxxi2c_board_info, ARRAY_SIZE(xxxi2c_board_info));
第一個參數是0還是1,我還不知道:-(
2、在另外一個設備驅動文件里,比如你放到/driver/char下做字符設備,一般是module_init(func_init())形式,則調用i2c_add_driver()即可,有幾個要定義:
static const struct i2c_device_id xxx_led_id[] = {
{ "abcd1", 0 }, /* 該名稱必須與BOARD_INFO的匹配才會調用probe函數 */
{ "abcd2", 0 },
{ }
};
MODULE_DEVICE_TABLE(i2c, xxx_led_id);
static struct i2c_driver xxx_led_driver = {
.driver = {
.name = "yourname", /* 該名字不需要與別的匹配 */
.owner = THIS_MODULE,
},
.probe = xxx_led_probe,
.remove = xxx_remove,
.id_table = xxx_led_id,
};
看到了吧,struct i2c_device_id里面的字符串與 I2C_BOARD_INFO里面的匹配后,xxx_led_probe才會調用。
如果不想用同一個probe,那就在寫一個struct i2c_device_id和struct i2c_driver
怎么樣,知道流程和每個結構體是干什么用的了吧?
