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

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

3天内不再提示

I2C总线相关的基本概念和通信流程解析

电子设计 来源:硬件助手 作者:硬件助手 2020-11-29 10:04 次阅读

本文主要介绍I2C总线相关的一些基本概念、通信流程、同步和仲裁、模式切换等。

I2C总线是PHILIPS公司推出的一种串行总线,是具备多主机系统所需的包括总线仲裁和高低速器件同步功能的高性能串行总线。

I2C物理上包括2条双向串行线,一条数据线SDA,一条时钟线SCL。均为OD结构,需要外部上拉,具体选取可参见之前的文章《硬件电路设计之“上下拉电阻”》。
SDA传输数据是大端传输(字节高位先传),每次传输8bit,即一字节。支持多主控(multi master),任何时间点只能有一个主控。总线上每个设备都有自己的一个addr,7bit或10bit,广播地址为全0。

1、基本概念
I2C总线上常用的一些基本概念如下:
主机:初始化发送,产生时钟信号和终止发送的器件。

从机:被主机寻址的器件。

发送器:发送数据到总线的器件。

接收器:从总线接收数据的器件。

多主机:同时有多于一个主机尝试控制总线,但不破坏报文。

仲裁:是一个在有多个主机同时尝试控制总线,但只允许其中一个控制总线并使报文不被破坏的过程。

同步:两个或多个器件同步时钟信号的过程。

总线空闲状态:I2C总线的SDA和SCL同时处于高电平时,规定为总线的空闲状态。此时各个器件的输出级场效应管均处在截止状态,即释放总线,由两条信号线各自的上拉电阻把电平拉高。

开始信号:SCL为高电平时,SDA由高电平向低电平跳变,开始传送数据。

结束信号:SCL为高电平时,SDA由低电平向高电平跳变,结束传送数据。

数据传输:SCL为高电平时,SDA线必须保持稳定,SDA上传输一个bit数据(电平采样);

数据改变:SCL为低电平时,SDA线才能改变电平。

I2C应答信号:主控每发送完8bit数据后等待从设备ACK。即在第9个CLK,若从设备发回ACK,SDA会被拉低(ACK信号为‘0’)。若没有ACK,SDA会被置高(NAK信号为‘1’),这会引起主控发生RESTART或STOP流程。

★NAK主要有两个作用:一是表示接收器未成功接收数据字节;二是当接收器是主机时(主机读数据),它收到最后一个字节后,应发送一个NAK信号,以通知从机结束数据发送,并释放总线,以便主机发送一个停止信号STOP。

2、基本通信流程
一次完整的I2C通信流程如下:
主设备发出开始信号(Start)。
主设备发出1字节的从设备地址信息,其中最低位为读写控制码(0为写,1为读),高7位为从设备地址码。
从设备发出ACK信号。
主设备开始对从设备进行读写操作。如果是读操作,则每读取1字节,主设备会发送一个应答信号(ACK)给从设备,如果是写操作,则每写入1字节,从设备会发送一个应答信号(ACK)给主设备。
主设备发出结束信号(Stop)。

3、10bit地址的发送
10bit地址的发送分两次发送,第一次发送高2bit和读写信号(高5bit固定为识别码11110),第二次发送低8bit,每次都有ACK信号。I2C规范并没有强制规定发送端在发送接收端地址后接收端非要做出响应不可,也可以默不作声,即便默不作声,发送端还是会继续工作,开始进行数据传输及读/写指令;

实际使用中10bit地址的寻址有两种方式:一种是只进行一次寻址,10bit地址的发送分两次发送,第一次发送高2bit和读写信号(实际读写操作),第二次发送低8bit。另一种是进行两次寻址,第一次寻址将10bit地址的发送分两次发送,第一次发送高2bit和读写信号,第二次发送低8bit;第二次寻址通过一个重复开始信号跟高2bit地址和读写信号(实际读写操作)进行二次寻址,第二次寻址只有第一次匹配上的从机会有应答。


主机发送数据时,当从机接收到开始条件后的10bit地址,从机就和它自己的地址比较从机地址的第一个字节(1111 0XX),并检查第八个bit(读写位)是否为0。有可能多个设备都匹配并产生应答(A1)。接下来所有从机开始匹配自己地址与第二个字节的8个bit(XXXXXXXX),这时就只有一个从机匹配并产生应答(A2)。被主机寻址匹配的从机会保持被寻址的状态直到接收到终止条件或者是重复开始条件后跟着一个不同的从机地址。

在第二个应答A2之前,处理过程与上面的一致。在重复开始条件(Sr)之后,匹配的从机会保持被寻址上的状态。这个从机会检查Sr之后的第一个字节的前7bit是否正确,然后测试第8bit是否为1(读)。如果这也匹配的话,从机就认定它被作为一个发送器被寻址到了并产生应答A3。从机会保持被寻址的状态直到接收到终止条件(P)或者重复开始条件(Sr)跟着一个不同的从机地址。然后这个时候的重复开始条件下,所有的从机会比较它们的地址与11110XX比较并测试第八位(读写位)。然而它们不会寻址到,因为对于10bit设备。读写位是1,或者对于7bit的设备,1111 0XX的从机地址不匹配。

4、同步和仲裁
所有主机在SCL线上产生它们自己的时钟来传输I2C总线上的报文。数据只在时钟的高电平周期有效。因此,需要一个确定的时钟进行逐位仲裁。

时钟同步通过线与连接I2C接口到SCL线来执行。这就是说:SCL线的高到低切换会使器件开始数它们的低电平周期,而且一旦器件的时钟变低电平,它会使SCL线保持这种状态直到到达时钟的高电平。但是,如果另一个时钟仍处于低电平周期,这个时钟的低到高切换不会改变SCL线的状态。因此,SCL线被有最长低电平周期的器件保持低电平。此时,低电平周期短的器件会进入高电平的等待状态。

当所有有关的器件数完了它们的低电平周期后,时钟线被释放并变成高电平。之后,器件时钟和SCL线的状态没有差别,而且所有器件会开始数它们的高电平周期。首先完成高电平周期的器件会再次将SCL线拉低。

这样,产生的同步SCL时钟的低电平周期由低电平时钟周期最长的器件决定,而高电平周期由高电平时钟周期最短的器件决定。

主机只能在总线空闲的时侯启动传输。两个或多个主机可能在起始条件的最小持续时间(tHD;STA)内产生一个起始条件,结果在总线上产生一个规定的起始条件。

当SCL线是高电平时,仲裁在SDA线发生。这样,在其他主机发送低电平时,发送高电平的主机将断开它的数据输出级,因为总线上的电平与它自己的电平不相同。

仲裁可以持续多位。它的第一个阶段是比较地址位。如果每个主机都尝试寻址相同的器件,仲裁会继续比较数据位(如果是主机)或者比较响应位(如果是主机)。因为I2C总线的地址和数据信息由赢得仲裁的主机决定,在仲裁过程中不会丢失信息。

丢失仲裁的主机可以产生时钟脉冲直到丢失仲裁的该字节末尾。

由于Hs模式的主机有一个唯一的8位主机码,因此一般在第一个字节就可以结束仲裁。

如果主机也结合了从机功能,而且在寻址阶段丢失仲裁,它很可能就是赢得仲裁的主机在寻址的器件。因此,丢失仲裁的主机必须立即切换到它的从机模式。

产生DATA1的主机的内部数据电平与SDA线的实际电平有一些差别,如果关断数据输出,这就意味着总线连接了一个高输出电平。这不会影响由赢得仲裁的主机初始化的数据传输。

由于I2C总线的控制只由地址或主机码以及竞争主机发送的数据决定,没有中央主机,总线也没有任何定制的优先权。
在串行传输时,当重复起始条件或停止条件发送到,I2C总线的时侯,仲裁过程仍在进行。如果可能产生这样的情况,有关的主机必须在帧格式相同位置发送这个重复起始条件或停止条件。也就是说,仲裁不能在下列情况之间进行:
重复起始条件和数据位

停止条件和数据位

重复起始条件和停止条件

从机不被卷入仲裁过程。

5、高速模式切换
Hs模式的串行数据传输格式符合标准模式I2C总线规范,Hs模式只能在下面的情况下(所有都在F/S模式)启动:

起始条件(S)

8位的主机码(00001XXX)

不响应位(A/)

主机码有两个主要的功能:
它允许在F/S模式速度下竞争主机之间仲裁和同步,结果得到一个获胜的主机。

它表示Hs模式传输的开始。

Hs主机码是保留的8位代码,它不用于从机寻址或其他目的。而且,由于每个主机都有唯一的主机码,I2C总线系统最多可以有8个Hs模式主机(主机码0000 1000应保留作测试和诊断用)。Hs模式主机器件的主机码是软件可编程的,由系统设计者决定。

以上就是针对I2C总线的一些基本介绍。

编辑:hfy


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

    关注

    8

    文章

    391

    浏览量

    61021
  • 串行总线
    +关注

    关注

    1

    文章

    183

    浏览量

    30654
  • 硬件接口
    +关注

    关注

    0

    文章

    44

    浏览量

    10856
收藏 人收藏

    评论

    相关推荐

    I2C总线上拉电阻阻值如何确定?

    导读I2C总线在产品设计中被广泛应用,尽管其结构简单,但经常发生上拉电阻设计不合理的问题。本文将对I2C上拉电阻的选择进行简要分析。一根信号线上,通过电阻连接一个固定的高电平VCC,信号线初始、空闲
    的头像 发表于 12-27 11:34 856次阅读
    <b class='flag-5'>I2C</b><b class='flag-5'>总线</b>上拉电阻阻值如何确定?

    I2C总线为什么要接上拉电阻

    输出。 为什么要接上拉电阻? 接上拉电阻是因为I2C通信需要输出高电平的能力。一般开漏输出无法输出高电平,如果在漏极接上拉电阻,则可以进行电平转换。 I2C由两条总线SDA和SCL组成
    的头像 发表于 11-20 10:07 499次阅读
    <b class='flag-5'>I2C</b><b class='flag-5'>总线</b>为什么要接上拉电阻

    详解I2C总线与SPI总线的区别

    I2C(Inter-Integrated Circuit)表示集成电路互连,是一种用于线路板内部芯片之间通信总线
    的头像 发表于 10-16 15:16 5190次阅读
    详解<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>与SPI<b class='flag-5'>总线</b>的区别

    了解I2C总线

    电子发烧友网站提供《了解I2C总线.pdf》资料免费下载
    发表于 10-08 11:13 2次下载
    了解<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>

    I2C总线上拉电阻计算

    电子发烧友网站提供《I2C总线上拉电阻计算.pdf》资料免费下载
    发表于 10-08 09:54 1次下载
    <b class='flag-5'>I2C</b><b class='flag-5'>总线</b>上拉电阻计算

    物联网嵌入式软件中的I2C总线设计详解

    基本概念、特点、通信协议,以及在不同场景下的高级应用和最佳实践。I2C接口只有2根信号线,总线上可以连接多个设备,硬件实现简单,可扩展性强。
    的头像 发表于 09-29 16:21 444次阅读
    物联网嵌入式软件中的<b class='flag-5'>I2C</b><b class='flag-5'>总线</b>设计详解

    I2C总线上拉电阻的必要性

    在电子通信领域,I2C总线作为一种广泛应用的双向串行通信协议,其稳定性和效率对于整个系统的性能至关重要。为了确保数据传输的可靠性,I2C
    的头像 发表于 09-09 17:16 1118次阅读

    优秀实践:I3C共享总线上的I2C器件

    电子发烧友网站提供《优秀实践:I3C共享总线上的I2C器件.pdf》资料免费下载
    发表于 09-06 09:49 0次下载
    优秀实践:<b class='flag-5'>I3C</b>共享<b class='flag-5'>总线</b>上的<b class='flag-5'>I2C</b>器件

    简单认识I2C通信协议

    I2C(Inter-Integrated Circuit)通信协议是由飞利浦公司(现为恩智浦半导体)开发的一种简单、双向二线制同步串行总线协议。自1982年发布以来,I2C协议因其高效
    的头像 发表于 07-25 18:06 1540次阅读

    I2C总线协议的工作原理和寻址格式

    I2C(Inter-Integrated Circuit)总线协议,即集成电路总线协议,是一种用于连接微控制器及其外围设备的串行总线协议。I2C
    的头像 发表于 05-27 15:47 1838次阅读

    SPI和I2C通信协议:应用与区别

    本文深入解析了SPI和I2C这两种通信协议的特点、工作原理和应用场景。SPI适用于高速数据传输,常用于存储器芯片和显示器驱动等领域;I2C适用于低速控制和传感器数据传输,常用于温度传感
    的头像 发表于 04-22 16:45 1873次阅读

    什么是I2C协议 I2C总线的控制逻辑

    在实际使用过程中,I2C比较容易出现的一个问题就是死锁 ,死锁在I2C中主要表现为:I2C死锁时表现为SCL为高,SDA一直为低。
    发表于 03-12 09:17 1096次阅读
    什么是<b class='flag-5'>I2C</b>协议 <b class='flag-5'>I2C</b><b class='flag-5'>总线</b>的控制逻辑

    蓝牙串口通讯总线——I2C/SPI/UART

    嵌入式工程师在做串口通信调试工作的时候,会经常用到I2C、SPI、UART这3条总线I2C、SPI、UART这三种通信
    的头像 发表于 01-22 09:41 1697次阅读
    蓝牙串口通讯<b class='flag-5'>总线</b>——<b class='flag-5'>I2C</b>/SPI/UART