0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看威廉希尔官方网站 视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

什么是IIC协议

汽车电子威廉希尔官方网站 来源:嵌入式之入坑笔记 作者:嵌入式之入坑笔记 2023-02-10 10:53 次阅读

1、IIC协议的诞生

IIC协议最早1982年由飞利浦公司设计开发,是一种两线制(SDA + SCL)的串行通行方式,提供了主从机之间通行的一种方案,在今天也是被广泛的应用在很多的产品设备上。

    一个使用IIC协议进行通信的设备,它既可以作为主机又可以作为从机(支持多主多从),并且它是一种半双工的通信方式。

IIC可以支持的通信速率范围较大,可以很好的满足多种设备的不同的通信速度的要求,它支持的速率有如下几个:

1)普通模式(100kHz即100kbps)

2)快速模式(Fm)(400kHz)

3)快速模式+(Fs+)(1MHz)

4)高速模式(Hs)(3.4MHz)

5)超高速模式(UFm)(5MHz)

2、IIC总线的术语说明

图片

3、SDL 线和 SCL线

IIC设备有两条接口线:串行数据 SDA 线和串行时钟 SCL 线。

    连接到IIC总线上的设备通过这两根线互相传递信息,SDA 和 SCL 都是双向线,可以互相之间进行信息的交互,但是是一种同步半双工的通信方式,同一时刻只能有一个方向进行数据的操作,不能同时进行。

IIC设备上的两根通信线一般示意如下:

图片

4、IIC总线协议

图片

4.1、IIC总线的起始信号

IIC总线发送启动信号的时序如图:

图片

发送启动信号时,时钟线SCL需要稳定的保持在高电位,SDA由高电位变化为低电位。启动信号发送完成之后就可以进行数据的发送了。

    如果在一次通信过程中,有两台以上的设备同时发出了起始信号,都希望获得总线控制权的话,那么第一个发出起始信号的设备将获得总线控制权,作为主设备开始传输数据。

注意:起始信号由主机负责产生。

4.2、停止信号

IIC总线发送停止信号的时序如图:

图片

停止信号是在时钟线SCL为高电位的时候,数据线SDA由低电平变化为高电平。停止信号一般是在通信完成之后或者通信失败退出之后发送的。

注意:停止信号由主机负责产生。

4.3、数据传输与有效性

IIC数据传输的协议如下:

图片

数据的传输是在发送完成了启动信号之后便可以进行数据的传输了。

    IIC协议要求在时钟信号SCL为高电位的期间,数据线SDA上的数据要保持稳定,不能发生变化(上图中1的位置)。只有在时钟信号SCL电位变低的时候,数据线SDA上的电平状态才能发生跳变。

    每一个数据的bit位传输需要一个时钟脉冲,一次传输最多是8bit。

一个完整的传输过程的通信时序如图:

图片

通信开始时,最开始发送的都是地址帧。比如,一个7Bit的地址,首先发出的是最高位,即读写位(1-读,0-写),用于指示是读操作还是写操作。

     帧的第9位是 **应答位(ACK/NACK)** 。所有帧(数据或地址)都是一样的。一旦发送帧的前8位,接收设备就可以控制数据线SDA。如果接收设备在第9个时钟脉冲没有将SDA线拉低进行应答,则可能是接收设备没有接收到数据,或者出现错误。在这种情况下,主机需要决定该做什么样的处理(一般考虑重发或者退出)。

    注意:SCL时钟信号由主机负责产生。数据的发送是高位先发的!

4.4、总线的仲裁

IIC总线支持多个主机同时在总线上发送数据,但是同一时刻只能有一个主机传送数据。因此必须要通过某些手段来决定哪个主机获得总线的控制权,其它的没有获得主机控制权的设备就只能进行等待,直到获得总线控制权才能进行数据的传输。

    IIC总线仲裁的方式有两种:时钟同步、仲裁。

4.4.1、时钟同步

时钟同步是通过时钟线SCL来实现的。在时钟信号SCL由高到低的切换过程中,IIC器件会开始数自身的低电平周期。当主器件的时钟信号变为低电平的时候,它会使SCL线保持这个电平状态直到达到高电平。假如这个时候有另外一个器件的时钟依然是处于低电平的周期,这个时钟的低到高的变化不会改变SCL线的状态。

    因此,SCL线被有着最长的低电平周期的器件占有总线的控制权,而这个时候低电平周期短的器件会进入高电平的等待状态,直到当前的主器件释放总线控制权,自身能够获得总线控制权才会改变这些状态。

时钟同步的时序示意图如下:

图片

4.4.2、仲裁

仲裁和同步一样,都是为了解决多主机情况下的总线控制冲突。仲裁的过程与从机无关。

    只有在总线空闲的时候主机才可以启动传输。两个主机可能在比较短的时间内在总线上同时产生一个有效的起始信号,这种情况下需要仲裁来决定由哪个主机占有总线控制权来完成数据传输。

    仲裁是逐位进行,在每一位数据的仲裁期间,当时钟线SCL为高电平时,每个主机都检查数据总线SDA上的电平是否和自己要发送的相同。

    这个过程需要持续很多位。理论上讲,如果两个主机所传输的内容完全相同,那么他们能够成功传输而不出现错误。但是,如果一个主机发送高电平但检测到SDA总线上的电平为低时,则认为自己仲裁失败并关闭自己的SDA数据线上的数据传输,而另一个主机则继续完成自己的传输。

IIC总线仲裁的时序示意图如下:

图片

5、IIC通信的流程

每个I2C设备都通过唯一的器件地址进行识别,根据设备功能,他们既可以是发送器也可作为接收器。通信的流程如下:

    1)IIC从机检测到IIC总线上的起始信号之后,就开始从总线上接收地址,之后会把从总线接收到的地址和自身的器件地址(通过软件编程)进行比较,一旦两个地址相同,IIC从机将发送一个确认应答(ACK),并响应总线的后续命令;

    2)发送或接收数据;

    3)发送或接收完成之后,在收到应答信号ACK之后结束数据的传输。

此外,如果软件开启了广播呼叫,则IIC从机始终对一个广播地址 (0x00)发送确认应答。I2C模块始终支持7位和10位的地址。

5.1、有关地址帧的发送

7 位地址的 IIC 通讯流程

图片

7Bit地址的通信中,开始信号之后的第一帧是地址帧+读写位,刚好是8Bit的数据,直接发送,等待从设备应答之后便可以进行数据的通信。

10 位地址的 IIC 通讯流程(主机发送)

图片

对于10-bit地的址设备,需要使用两个帧来传输10Bit的slave地址。

    第一个帧的前5bit固定为b11110xx,后接slave地址的高2位,第8位仍然是读写(R/W)位,接着是一个ACK位,由于总线上可能有多个10 Bit 从设备地址的高2bit相同,因此这个ACK可能由多有slave设备返回。

    第二个帧紧接着第一帧发送,包含slave地址的低8位(7:0),接着该地址的slave回复一个ACK(或NACK)。

    注意:10-bit地址的设备和7-bit地址的设备在总线中是可以并存的,因为7-bit地址的高5位不可能是b11110。

10 位地址的 I2C 通讯流程(主机接收)

图片

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • SDA
    SDA
    +关注

    关注

    0

    文章

    124

    浏览量

    28129
  • SCL
    SCL
    +关注

    关注

    1

    文章

    239

    浏览量

    17057
  • IIC协议
    +关注

    关注

    0

    文章

    16

    浏览量

    3931
  • 串行通行
    +关注

    关注

    0

    文章

    2

    浏览量

    1111
收藏 人收藏

    评论

    相关推荐

    FPGA实现IIC协议的设计

    今天给大家带来的是IIC通信,IIC协议应用非常广泛,例如与MPU6050进行通信,配置OV5640摄像头、驱动OLED屏幕等等,都需要使用到IIC
    的头像 发表于 03-04 10:49 1249次阅读
    FPGA实现<b class='flag-5'>IIC</b><b class='flag-5'>协议</b>的设计

    IIC协议显示屏

    我现有国外产品,他的显示是通过IIC协议发送到128*64的显示评上的,我怎么才能把传送来的数据提取出来呢如果有大牛可以解决,愿意有偿合作。电话:***
    发表于 03-15 10:45

    STM32的IIC协议

    今天在使用STM32读取6050数据时发现了一个问题,为什么战舰,野火的视频中都使用模拟的IIC协议,而不使用自动的IIC协议???经过多方查询了解到STM32为了规避飞利浦专利的问题
    发表于 11-20 22:09

    关于IIC协议

    IIC协议在开始信号产生后,发送了一个数据也产生了应答,如果没有结束信号又直接开始信号这样可以吗?
    发表于 04-07 13:34

    IIC协议分析

    IIC协议分析
    发表于 04-30 15:49

    STM32的IIC协议简介

    文章目录(一)IIC协议简介(二)物理层和协议层简介(三)IIC物理层:3.1、物理层的特点(四)IIC
    发表于 01-05 06:13

    IIC协议的相关资料推荐

    STM32 IIC实验讲解,从入门到放弃。文章目录STM32 IIC实验讲解,从入门到放弃。前言一、IICIIC是什么?IIC协议二、代码部分IIC
    发表于 01-17 08:12

    FPGA IIC协议的相关资料分享

    FPGA IIC协议
    发表于 01-18 07:51

    起始信号和停止信号在IIC协议中是如何规定的

    什么是IIC协议?起始信号和停止信号在IIC协议中是如何规定的?
    发表于 01-24 06:54

    IIC协议软件模拟方法

    关于iic协议和对AT24C16进行读写数据的代码解读认识IIC协议IIC协议软件模拟方法功能快
    发表于 02-09 07:00

    IIC协议的相关资料下载

    关于MPU6050学习的一些总结之二IIC协议前言一、IIC总线前言在查阅并了解了MPU6050的芯片手册后,已经对MPU6050有了大致的了解。那么接下来如何使MPU6050工作并且读取内部寄存器
    发表于 02-10 06:02

    IIC协议是如何进行通信的呢

    IIC协议是什么?IIC协议用来干什么?IIC协议是如何进行通信的呢?
    发表于 02-10 07:07

    如何使用代码实现的IIC协议

    1. 综述  由上篇博客可知道IIC协议如何用代码实现,本篇博客就不涉及协议内容,只讲解如何使用。  本次的实验传感为:DS3231(时钟模块),对于时钟模块的具体信息我也就不多介绍,大家可以自行度
    发表于 02-21 06:36

    IIC协议超详细解释(适合小白入门)

    以下内容,将解释以下几个问题1.IIC协议是什么?2.IIC协议用来干什么?3.IIC协议的通信
    发表于 12-07 14:21 5次下载
    <b class='flag-5'>IIC</b><b class='flag-5'>协议</b>超详细解释(适合小白入门)

    MSP430F5529软件模拟IIC协议

    MSP430F5529软件模拟IIC协议
    发表于 11-24 16:35 0次下载