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

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

3天内不再提示

I2C通信协议及其工作原理

柴火创客空间 来源:柴火创客空间 2023-04-19 09:36 次阅读

"也许你听说过I2C,或者你也正在使用I2C,但你有没有了解过什么是I2C?I2C是如何工作的?让我们一起了解一下什么是I2C?以及它的工作原理吧!"

什么是I2C

I²C(Inter-Integrated Circuit)是一种使用多主从结构的串行通信总线。它是由飞利浦在20世纪80年代初设计的。I2C对于主板、嵌入式系统手机和外围元件之间的通信是很方便的。由于其简单性,I2C被广泛用于微控制器传感器、显示器、物联网设备、EEPROM等的通信。I2C由两条线组成,SCL和SDA,这两条数据线需要连接到上拉电阻,当总线处于空闲状态时,SCL和SDA处于高电平,I2C总线按照一定的协议工作。

接下来,让我们看一下I2C协议。I2C支持多个从属设备,也就是说,多个I2C从属设备可以连接到一个I2C控制器上。这些不同的I2C从属设备有不同的设备地址,这样I2C主控制器可以通过I2C设备的设备地址访问指定的设备地址,一条I2C总线连接多个I2C设备,如图所示:

317192ee-ddf5-11ed-bfe3-dac502259ad0.png

SDA和SCL链接必须连接到一个上拉电阻,通常是4.7KΩ。其余的I2C从机与SDA和SCL线相连接,这样就可以通过SDA和SCL线访问多个I2C设备。

3186416c-ddf5-11ed-bfe3-dac502259ad0.png

I2C的特点

1. 只需要一条数据线SDA和一条时钟线SCL,SDA(串行数据线)和SCL(串行时钟线)都是双向的I/O线

SCL(串行时钟):串行时钟线,用于传输CLK信号,一般由主设备提供给从设备

SDA(串行数据):串行数据线,传输通信数据

2. 实现真正的多主总线,任何设备都可以同时作为主设备和从设备,但同时只能有一个主设备

3. 可以通过外部连接进行检测,便于系统故障诊断和调试

4. 连接在同一总线上的IC只受限于总线的最大电容,串行8位双向数据传输比特率在标准模式下可达100Kbit/s,在快速模式下可达400Kbit/s,在高速模式下可达3.4Mbit/s。

5. 总线上消耗的电流非常小。因此,在总线上扩展的设备数量主要由电容性负载决定,它可以抵抗高噪音干扰。增加一个总线驱动器可以使总线电容扩大10倍,传输距离可以达到15米;兼容不同电压等级的设备,工作温度范围广

6.接口电路是一个开路输出。它需要通过一个上拉电阻连接到电源VCC。当总线处于空闲状态时,两条线都是高电平。连接到总线上的外部器件是CMOS器件。输出端也是一个开路电路。

CORPORATE CULTURE

数据传输

主设备和从设备遵循以下协议格式进行数据传输。数据在主设备和从设备之间通过SDA数据线传输0和1的串行数据,一个串行数据序列的结构可以分为:

起始位

地址位(7bit或10bit)。

读和写位(1bit)

响应位(1bit)

数据位+响应位(数据位8bit;响应位1bit;数据+响应可反复多次传输,直至遇到停止位)

停止位

31a3c48a-ddf5-11ed-bfe3-dac502259ad0.png

启动位

当主设备决定开始通信时,它需要发送一个启动信号,并需要进行以下操作

首先,将SDA从VOH切换到VOL

然后将SCL从VOH切换到VOL

在主设备发出信号和启动条件后,所有的从属设备即使在睡眠模式下也会变得活跃,并等待接收一个地址位。

31b225de-ddf5-11ed-bfe3-dac502259ad0.png

地址位

地址位支持7位和10位,如果主站需要向从站发送/接收数据,必须先发送地址,然后从站才会对应,再与安装在总线上的从站地址相匹配。

响应位

响应位有2种类型:

ACK:从机正确接收数据或地址位+读写位

NACK:从机不回答,工作不正常。

每次主设备发送数据和读写位时,它将等待从属设备的响应信号ACK。

如果从属设备发来响应位信号ACK

如果没有响应信号NACK,SDA将输出一个VOH,这将导致主设备重新启动或停止

31c3ee9a-ddf5-11ed-bfe3-dac502259ad0.png

数据位

每次传输的数据总共有8位,由发送方设置,它需要将数据位传输给接收方。

传输后有一个ACK/NACK位,如果接收方成功接收了数据,从属方就发送一个ACK。否则,从机发送一个NACK。

数据可以多次发送,直到收到一个停止位。

停止位

当主设备决定结束通信时,它需要发送结束信号,并需要执行以下操作。

首先将SDA从VOL切换到VOH

然后SCL从VOH切换到VOL

31da9668-ddf5-11ed-bfe3-dac502259ad0.png

下面是显示完成的I2C时序图:

31ebb4b6-ddf5-11ed-bfe3-dac502259ad0.png

SCL线的同步化(时钟同步化)

SCL的同步是由于总线线 "AND"(开漏输出)的逻辑功能,也就是说,只要有一个节点发送低电平,总线就会显示为低电平。只有当所有节点都发送高电平时,总线才能出现高电平。正是由于线路 "AND "逻辑功能的原理,当多个节点同时发送时钟信号时,总线上会显示一个统一的时钟信号,这就是SCL的同步原理。

31fb5d8a-ddf5-11ed-bfe3-dac502259ad0.png

CORPORATE CULTURE

SDA仲裁

SDA仲裁

SDA线的仲裁也是基于总线具有线路 "AND "逻辑功能的原则。节点发送1位数据后,比较总线上呈现的数据是否与它发送的内容一致(类似于CAN总线的回读机制),一致继续发送否则退出竞争。SDA线的仲裁可以确保I2C总线系统正常通信,当多个主节点试图同时控制总线时,数据不会丢失。总线系统通过仲裁只允许一个主节点继续占用总线。

仲裁过程

DATA1和DATA2分别是主节点发送给总线的数据信号,SDA是总线上呈现的数据信号,SCL是总线上呈现的时钟信号。当主节点1和2同时发送启动信号时,两个主节点都发送高电平信号,这时,总线上的信号为高电平,两个主节点检测到总线上的信号与自己发送的信号相同,继续发送数据。在第二个时钟周期,两个主节点都发送低电平信号,总线上呈现的信号为低电平,继续发送数据。在第3个时钟周期,主节点1发送一个高电平信号,而主节点2发送一个低电平信号,根据总线的 "AND "线的逻辑功能,总线上的信号是低电平。这时,主节点1检测到总线上的数据与自己发送的数据不同,并断开数据的输出阶段,转向从机接收状态,这样主节点2赢得了总线数据没有丢失,即总线上的数据与主节点2发送的数据相同,主节点1转为从节点后继续接收数据,也没有丢失SDA线。因此在仲裁过程中,数据不会丢失。

小结:SDA仲裁和SCL时钟同步处理不是顺序进行的,而是同时进行的。在实际使用中,I2C很容易出现死锁。有两种常见的情况会发生死锁:

一种情况是,当从属设备回复ACK时,主设备异常复位。

另一种情况是,当从属设备回复的数据位为0时,主设备异常复位。

这两种情况的相同点是,当主设备被异常复位时,SDA处于被从属设备拉低的状态,而SCL在主设备复位后处于VOH(空闲状态)。此时,从设备将等待主设备将SCL拉低,以获取ACK或数据位,而主设备将等待从设备释放SDA线。主设备和从设备互相等待,在空中互相对视,进入死锁状态。

下面是一些解决死锁问题的常用方法:主设备检测到SDA线后,从设备就会释放SDA线。

主设备检测到SDA被拉低超过一段时间后,会主动复位从设备释放SDA。这种方法的前提是,从属设备有一个复位引脚,MCU可以控制从属设备的复位引脚使其复位。

在主设备检测到SDA被拉低超过一段时间后,它向时钟总线推送9个时钟,并占用从属设备的ACK位,这样从属设备就会释放SDA到一个VOH。

在主设备和从设备之间串联一个I2C缓冲器,它可以自动检测死锁情况。当检测到死锁时,它将主动断开与主设备的连接,并向从设备发送9个时钟。在从属设备释放SDA线后,它将重新与主设备建立连接。

I2C死锁问题不能从根本上避免,除了由MCU的异常复位引起的I2C死锁外,在正常的通信过程中,从属设备也可能异常地拉下SDA而引起死锁。因此,当死锁发生时,软件应设计成能够从死锁中恢复,从而使I2C通信能够继续。

CORPORATE CULTURE 时钟拉伸

时钟拉伸

什么是I2C时钟拉伸?在I2C的主从通信过程中,总线上的SCL时钟总是由主站产生和控制,但如果从站不能跟上主站的速度,I2C协议规定从站可以拉低SCL时钟线。传输会暂停,直到从机释放SCL线,然后继续传输。

320e963e-ddf5-11ed-bfe3-dac502259ad0.png

时钟拉伸是从属设备的一个可选配置。如果不启用,从机不能控制SCL;如果启用,从机可以通过强行将SCL拉低来降低传输速度。在SCL为VOL的期间,主机只能等待从机释放SCL。

CORPORATE CULTURE

重复启动

有时,主站需要在一次通信中进行多次信息交换,如与不同的从站传输信息,或切换读写操作,而又不想在此期间被其他主站干扰,那么可以使用 "重复启动条件"--在一次通信中,主站可以产生多个启动条件来完成多个信息交换,最后产生一个停止条件来结束整个通信过程。由于在此期间没有停止条件,所以主站一直占据着窃听器,而其他主站无法切换进来。

322290bc-ddf5-11ed-bfe3-dac502259ad0.png

CORPORATE CULTURE

下面是UART、I2c和SPI之间的区别

322fe4d8-ddf5-11ed-bfe3-dac502259ad0.png

你可能想知道,这三种通信方式中哪一种是最好的?是UART、I2C,还是SPI?

实际是没有最好的通信外设,每个通信外设都有自己的优点和缺点。

因此,用户应该选择最适合他们项目的通信外设。例如,如果你想要最快的通信外设,SPI将是最理想的。另一方面,如果用户想连接多个设备而又不太复杂,I2C将是最理想的,因为它可以连接多达127个设备,而且易于管理。

以下是一些支持I2C通信协议的产品

Seeeduino XIAO 系列

所有支持I2C、UART或SPI的XIAO系列单片机,这里有链接你可以查看Seeed Studio XIAO系列产品。

以下是XIAO系列的一些特点

拇指大小的外形尺寸,只有20×17.5毫米。专为空间受限的情况而制造。

多达11个可用IO支持多种接口,包括模拟、数字、IIC、UART、SPI等。

强大的内核,性能强大,适合多样化和复杂的应用。

轻松地将XIAO集成到其他板子上,实现大规模生产。

Wio Terminal

Wio Terminal是一个基于ATSAMD51的微控制器,具有蓝牙Wi-Fi无线连接功能,由Realtek RTL8720DN提供支持,与Arduino和MicroPython兼容。

以下是Wio终端的一些特点

强大的MCU:Microchip ATSAMD51P19的ARM Cortex-M4F内核,运行频率为120MHz。

可靠的无线连接:配备Realtek RTL8720DN,双频2.4Ghz/5Ghz Wi-Fi

完整的系统配备有屏幕+开发板+输入/输出接口+外壳

树莓派40针兼容的GPIO,可以作为树莓派的外围设备进行安装

支持Arduino、CircuitPython、Micropython、ArduPy(什么是ArduPy)、AT固件、Visual Studio代码

支持USB OTG

CORPORATE CULTURE

写在最后

I2C(Inter-Integrated circuit)协议是电子传输信号中常用的一种协议。

它是一种两线式串行双向总线,用于连接微控制器和外部设备,也因为它所需的引脚数只需要两条(CLK和DATA),硬件实现简单,可扩展性强,所以被广泛应用于系统内多个集成电路IC间的通信。

审核编辑:汤梓红

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

    关注

    112

    文章

    15235

    浏览量

    171206
  • 通信协议
    +关注

    关注

    28

    文章

    739

    浏览量

    39749
  • 总线
    +关注

    关注

    10

    文章

    2706

    浏览量

    87222
  • I2C
    I2C
    +关注

    关注

    28

    文章

    1347

    浏览量

    120830
  • SDA
    SDA
    +关注

    关注

    0

    文章

    122

    浏览量

    27556

原文标题:网络通信 | I2C通信协议及其工作原理

文章出处:【微信号:ChaiHuoMakerSpace,微信公众号:柴火创客空间】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    3分钟理解通信协议I2C总线 #通信协议

    通信协议I2CI2C总线总线/接口技术
    硬声课堂
    发布于 :2021年10月18日 10:39:12

    I2C通信协议手册找不到广为流传的内容

    在学习I2C通信协议的时候,翻了一遍I2C协议手册,却找不到:“在进行I2C通信发送数据的时候,
    发表于 04-05 00:27

    I2C通信协议介绍

    的串行通信协议主要有EIA-232、EIA-232、EIA-485、USB、IEEE 1394几种: 以下着重介绍I2C总线:一、I2C总线概述:I2C总线是PHLIPS公司推出的一种
    发表于 07-19 02:36

    i2c通信协议

    1.1 i2c通信协议通信协议:用来实现数据传输。i2c物理总线:SCL(时钟线) SDA(数据线)i2c
    发表于 03-06 16:15

    请问I2C协议的问题

    我看写I2C通信协议的,比如启动协议有:SDA=1;//发送起始条件的数据信号_Nop();SCL=1;_Nop(); //起始条件建立时间大于4.7us,延时_Nop();_Nop();_Nop
    发表于 04-12 14:49

    什么是软件I2C和硬件I2C

    学习I2C总线通信协议,完成基于I2C硬件协议的AHT20温湿度传感器的数据采集,并将采集的温度-湿度值通过串口输出。具体任务:1)解释什么是“软件
    发表于 08-23 06:19

    I2C通信协议硬软件

    目录12C通信协议硬软件I2CAHT20测温湿度参考12C通信协议I2C
    发表于 08-23 07:42

    I2C通信协议简介

    一.I2C通信协议简介1.物理层I2C物理层有以下特点:I2C是支持多设备的总线,支持多个通讯主机、多个通讯从机I2C使用两条总线线路,SD
    发表于 01-13 07:20

    STM32的I2C特性是什么?

    I2C通信协议具有哪些特点?常见的I2C通信系统有哪些?STM32的I2C特性是什么?
    发表于 01-18 07:44

    I2C工作模式有哪几种

    I2C是一种是串行总线接口连接协议,它也被称为TWI(双线接口),因为它只使用两条线缆进行通信,这两条线分别是SDA(串行数据)和SCL(串行时钟)。I2C是一种即时应答的
    发表于 02-16 06:36

    SPI通信协议讲解相关资料推荐

    SPI通信协议讲解SPI通信概念SPI通信SPI 物理层协议层SPI 基本通讯过程通讯的起始和停止信号数据有效性CPOL/CPHA 及通讯模式通讯引脚SPI
    发表于 02-17 06:09

    I2C通信协议的原理是什么

    I2C通信协议I2C通信原理I2C通信原理:I2C
    发表于 02-17 07:16

    I2C总线通信协议的相关资料下载

    基于I2C总线通信协议的温度采集实验(基于AHT20) I2C总线通信协议简介 AHT20简介 一.项目说明1)实战目标:2)实战元件: 二
    发表于 02-22 07:37

    I2C的发送过程分享

    序本文将以51单片机的I2C通信协议为例,将涉及到I2C的基本过程以及其中我认为比较重要的点。I2C的基本过程首先:IIC作为一种串行
    发表于 02-23 06:11

    I2C到底能做什么?

    什么?什么类型的设备使用I2CI2C如何帮我解决系统中遇到的实际问题?I2C是使主设备(例如处理器,微控制器(MCU)或专用集成电路(ASIC))能够与同一双线总线上的其它外围设备通信
    发表于 11-15 07:31