I2C总线通信协议

I2C总线通信协议

1. I2C总线简介

I2C是Inter-Integrated Circuit的简称,读做:I-squared-C。由飞利浦公司于1980年代提出,为了让主板、嵌入式系统或手机用以链接低速周边外部设备而发展。html

主要用途:并发

SOC和周边外设间的通讯(如:EEPROM,电容触摸芯片,各类Sensor等)。ui

1.1 物理接口

I2C总线只使用两条双向漏极开路的信号线(串行数据线:SDA,及串行时钟线:SCL),并利用电阻上拉。I2C总线仅仅使用SCL、SDA两根信号线,就实现了设备间的数据交互,极大地简化了对硬件资源和PCB板布线空间的占用。I2C总线普遍应用在EEPROM、实时时钟、LCD、及其余芯片的接口。I2C容许至关大的工做电压范围,典型的电压基准为:+3.3V或+5V。3d

SCL(Serial Clock):串行时钟线,传输CLK信号,通常是主设备向从设备提供
SDA(Serial Data):串行数据线,传输通讯数据code

I2C总线接口内部结构以下图所示:htm

I2C总线接口内部结构

I2C使用一个7bit的设备地址,一组总线最多和112个节点通讯。最大通讯数量受限于地址空间及400pF的总线电容。blog

常见的I2C总线以传输速率的不一样分为不一样的模式:标准模式(100Kbit/s)、低速模式(10Kbit/s)、快速模式(400Kbit/s)、高速模式(3.4Mbit/s),时钟频率能够被降低到零,即暂停通讯。接口

该总线是一种多主控总线,便可以在总线上放置多个主设备节点,在中止位(P)发出后,即通信结束后,主设备节点能够成为从设备节点。资源

主设备节点:产生时钟并发起通讯的设备节点
从设备节点:接收时钟并响应主设备节点寻址的设备节点get

1)I2C通讯双方地位不对等,通讯由主设备发起,并主导传输过程,从设备按I2C协议接收主设备发送的数据,并及时给出响应。
 2)主设备、从设备由通讯双方决定(I2C协议自己无规定),既能当主设备,也能当从设备(须要软件进行配置)。
 3)主设备负责调度总线,决定某一时刻和哪一个从设备通讯。同一时刻,I2C总线上只能有一对主设备、从设备通讯。
 4)每一个I2C从设备在I2C总线通信中有一个I2C从设备地址,该地址惟一,是从设备的固有属性,通讯中主设备经过从设备地址来找到从设备。

I2C总线多主设备结构以下图所示:

I2C总线多主设备结构

1.2 通信特征

串行、同步、非差分、低速率

1)串行通讯,全部的数据以位为单位在SDA线上串行传输
2)同步通讯,即双方工做在同一个时钟下,通常是通讯的A方经过一根CLK信号线,将A设备的时钟传输到B设备,B设备在A设备传输的时钟下工做。同步通讯的特征是:通讯线中有CLK。
3)非差分,I2C通讯速率不高,且通讯距离近,使用电平信号通讯。
4)低速率,I2C通常是同一个板子上的两个IC芯片间通讯,数据量不大,速率低。速率:几百KHz,速率可能不一样,不能超过IC的最高速率。

1.3 I2C总线状态

I2C总线上有两种状态:

空闲态:没有设备发生通讯。
忙态:其中一个从设备和主设备通讯,I2C总线被占用,其余从设备处于等待状态。

2. I2C总线通讯协议

时序:在通讯中时序是通讯线上按时间顺序发生的电平变化,及这些电平变化对通讯的意义。

每一个通讯周期都由一个起始位开始通讯,由一个结束位结束通讯,中间部分是传递的数据。

每一个通讯周期,主设备会先发8位的从设备地址(从设备地址由高7位的实际从设备地址和低1位的读/写标志位组成),主设备以广播的形式发送从设备地址,I2C总线上的全部从设备收到地址后,判断从设备地址是否匹配,不匹配的从设备继续等待,匹配的设备发出一个应答信号。

同一时刻,主设备、从设备只能有一个设备发送数据。

2.1 起始位和结束位

I2C总线通信由起始位开始通信,由结束位中止通信,并释放I2C总线。起始位和结束位都由主设备发出。
起始位(S):在SCL为高电平时,SDA由高电平变为低电平
结束位(P):在SCL为高电平时,SDA由低电平变为高电平

以下图所示:

I2C的起始位与中止位

2.2 数据格式与应答

I2C数据以字节(即8bits)为单位传输,每一个字节传输完后都会有一个ACK应答信号。应答信号的时钟是由主设备产生的。

应答(ACK):拉低SDA线,并在SCL为高电平期间保持SDA线为低电平
非应答(NOACK):不要拉低SDA线(此时SDA线为高电平),并在SCL为高电平期间保持SDA线为高电平

在传输期间,若是从设备来不及处理主设备发送的数据,从设备会保持SCL线为低电平,强迫主设备等待从设备释放SCL线,直到从设备处理完后,释放SCL线,接着进行数据传输。

以下图所示:

I2C的数据格式与应答信号

2.3 数据传输通信

1)写数据

开始数据传输后,先发送一个起始位(S),主设备发送一个地址数据(由7bit的从设备地址,和最低位的写标志位组成的8bit字节数据,该读写标志位决定数据的传输方向),而后,主设备释放SDA线,并等待从设备的应答信号(ACK)。每个字节数据的传输都要跟一个应答信号位。数据传输以中止位(P)结束,而且释放I2C总线。

2)读数据

开始通信时,主设备先发送一个起始信号(S),主设备发送一个地址数据(由7bit的从设备地址,和最低位的写标志位组成的8bit字节数据),而后,主设备释放SDA线,并等待从设备的应答信号(ACK),从设备应答主设备后,主设备再发送要读取的寄存器地址,从设备应答主设备(ACK),主设备再次发送起始信号(Sr),主设备发送设备地址(包含读标志),从设备应答主设备,并将该寄存器的值发送给主设备;

读取单字节数据
主设备要读取的数据,若是是只有一个字节的数值,就要结束应答,主设备要先发送一个非应答信号(NOACK),再发送结束信号(P);
读取多字节数据
主设备要读取的数据,若是是大于一个字节的多个数据,就发送ACK应答信号(ACK),而不是非应答信号(NOACK),而后主设备再次接收从设备发送的数据,依次类推,直到主设备读取的数值是最后一个字节数据后,须要主设备给从设备发送非应答信号(NOACK),再发送结束信号(P),结束I2C通信,并释放I2C总线。

I2C的数据传输

注意:全部的数据传输过程当中,SDA线的电平变化必须在SCL为低电平时进行,SDA线的电平在SCL线为高电平时要保持稳定不变。以下图所示:

I2C数据位变化与时钟线关系

3. 总结

本文讲述了I2C总线的特征和总线协议,具体的实现方法有两种:

一种是:I2C总线协议的软件模拟实现方法。 另外一种是:Linux内核中I2C模块的实现方法。

相关文章
相关标签/搜索