说明:此文档不具体介绍实现细节,关注在i2c bus(i2c controller)驱动的框架,以此对i2c bus驱动有个总体认知,具体的软件对i2c controller的操作细节依赖于具体芯片i2c控制器的设计实现,一来绝大部分人很少从事此类工作,二来需要有资源能够查看具体的spec,通常这是很难的。
i2c bus(i2c controller)具体是怎么与i2c slave进行数据传输呢?
做驱动的都知道 i2c slave设备是最常见不过的了,也都清楚slave将需要传输的读写数据整理成一个个i2c_msg,然后通过i2c core调用事先注册好的i2c controller实现的master_xfer回调函数进行数据传输。然而i2c controller的master_xfer具体对数据的传输是怎么处理的,这个细节清楚的人并不多。
本文将结合本人的实际工作经验对i2c controller的master_xfer的工作方式做简要框架性的介绍。希望对大家实际问题的处理有一些指导作用。
本文主要从三个方面来介绍:
- 驱动加载和初始化的 probe函数;
- 总线数据传输处理回调函数 master_xfer;
- 中断处理过程(顶半部 + 底半部)。
1. probe
probe函数部分主要分两大部分:
一个是跟平台i2c总线控制器强相关的,主要是dts,clk,enable;
另一个是通用部分,主要是注册中断和注册adapter到i2c core。
static int xxx_i2c_probe(struct platform_device *pdev)
{
//Part 1: particular part for specific platform i2c bus(controller)
/* 1. Parse dts info into i2c controller driver_data_struct */
/* 2. i2c controller clk init && clk enable */
/* 3. i2c controller enable */
--------------------------