I2C详解(二)

article/2025/11/7 1:58:30

7-bit寻址数据传输

常见的传输方向及格式有如下两种:

  • 主机写数据-从机接收,传输方向不变

要进行数据写入从机,首先主机发送START条件+从机地址+R/W=0(写操作,设置为0),从机读取到该地址后回应ACK,主机将继续发送需要操作的寄存器地址,从机继续回应ACK,表示从机准备完毕。之后主机发送寄存器的数据(可能是1byte也可能是多个byte),每个byte从机都会回应ACK,发送完成后,主机发送STOP命令,将总线释放,完成写操作。如下图示意:
在这里插入图片描述

  • 主机读数据-从机发送,传输方向改变

读数据与写数据相似,但读数据会多几个步骤。要想从从机读取数据,首先要知道从机地址以及寄存器地址,这两部需要进行读操作来实现,和读操作一致。读操作完成后,主机发送重复开始+从机地址+R/W=1(读操作,设置为1),从机返回ACK,此时主机释放SDA线转由从机控制,主机读取SDA总线进行数据接收,每发送1 byte数据,主机会响应ACK表示还需要再接收数据。当主机接收完想要的数据后,主机将会返回NACK,告诉从机释放SDA总线,随后主机发送STOP命令,将总线释放,完成读操作。如下图示意:
在这里插入图片描述


10-bit寻址数据传输

采用10位地址位扩充了I2C的地址范围,7位和10位地址设备都可以共存于同一个I2C总线系统。并且可以工作在所有速度模式。当然,目前使用10位地址系统的I2C设备不多。

注:7位和10位地址设备都可以共存于同一个I2C总线系统,因为位地址系统的高5位不可能是11110

10位从机地址由START或者Repeated Start 后两个字节决定。第一个字节的前7位格式为1111 0XX,其中XX代表10位地址最高两位(MSB),第一个字节的第8位代表R/W位。

常见的数据传输格式和7位地址一致,如下示意:

  • 主机写数据-从机接收,传输方向不变

在这里插入图片描述

  • 主机读数据-从机发送,传输方向改变

在这里插入图片描述


时钟同步与仲裁

如果两个master都想在同一条空闲总线上传输,此时必须能够使用某种机制来选择将总线控制权交给哪个master,这是通过时钟同步和仲裁来完成的,而被迫让出控制权的master则需要等待总线空闲后再继续传输。在单一master的系统上无需实现时钟同步和仲裁。

  • 时钟同步(Clock synchronization )

时钟同步是通过I2C总线上的SCL之间的线“与”(wired-AND)来完成的,即如果有多个主机同时产生时钟,那么只有所有master都发送高电平时,SCL上才表现为高电平,否则SCL都表现为低电平。**SCL总线上低电平时间是所有主机时钟中最长的低电平时间,其高电平时间是所有主机时钟中最短的高电平时间。**

在这里插入图片描述

  • 数据仲裁(Arbitration)

总线仲裁和时钟同步类似,当所有主机在SDA上都写1时,SDA的数据才是1,只要有一个主机写0,那此时SDA上的数据就是0。一个主机每发送一个bit数据,在SCL处于高电平时,就检查看SDA的电平是否和发送的数据一致,如果不一致,这个主机便知道自己输掉仲裁,然后停止向SDA写数据。也就是说,如果主机一直检查到总线上数据和自己发送的数据一致,则继续传输,这样在仲裁过程中就保证了赢得仲裁的master不会丢失数据。 输掉仲裁的主机在检测到自己输了之后也不再产生时钟脉冲,并且要在总线空闲时才能重新传输。 仲裁的过程可能要经过多个bit的发送和检查,实际上两个主机如果发送的时序和数据完全一样,则两个主机都能正常完成整个的数据传输。

在这里插入图片描述


时钟拉伸(Clock stretching)

有时候低速从机可能由于上一个请求还没处理完,无法继续接收主机的后续请求,即主机的数据传输速率超过了从机的处理能力。这种情况下,从机可以进行时钟拉伸来要求主机暂停传输数据 。通常时钟都是由主机提供的,从机只是在SDA上读数据或者发数据。
时钟拉伸则是从机在主机释放SCL后,将SCL主动拉低并保持,此时要求主机停止在SCL上产生脉冲以及在SDA上发送数据,直到从机释放SCL(SCL为高电平)。之后主机便可以继续正常的数据传输了。可见时钟拉伸实际上是利用了时钟同步的机制,只是时钟由从机产生。 如果系统中存在这种低速从机并且从机实现了时钟拉伸,主机必须能够处理这种情况,实际上大部分从机设备中不包含SCL驱动器的,因此无法拉伸时钟。


保留地址(Reserved addresses)

有两组 0000 XXX and 1111 XXX作为保留地址,详见下表:

在这里插入图片描述
注:7bit 理论可以连接2^7=128个外设,由于上图16个指令有特殊定义,所以可用的地址为112个。虽然最大的外设节点数目是被地址空间所限制住,但实际上也会被总线上的总电容所限制住,一般而言最大为400 pF。


通用广播地址(General call address)

通用广播地址是为了寻址总线上所有设备。如果一个设备不需要使用广播功能,可以不响应广播。如果设备需要使用广播功能,则它在检测到广播地址后发送响应,并作为从机接收读取总线上发送的数据。主机不知道总线上有多少从机发送响应。总线上所有可以响应广播的从机读取广播地址后的第二个及后面的字节。不能处理这些广播数据的从机通过不发送响应的方式忽略它。同样地,如果有一个或一个以上的从机发送响应,则主机就检测不到总线上其它没有响应的设备。广播消息的含义总是定义在第二个字节。

在这里插入图片描述

有两种可能情况:

  • 最低位“B”为0
  • 最低位“B”为1

“B”为0,第二个字节包括以下定义:

  • 0000 0110(06h):复位并通过硬件写内容到从机的可编程部分。所有可以响应此类广播的从机,收到此两字节后,进行复位并进入它们地址的可编程部分。注意确保设备在加电后不会将SDA或SCL拉低,因为这些低电平会阻塞总线;
  • 0000 0100(04h):通过硬件写内容到从机的可编程部分,作用类似(06h),但设备不会复位;
  • 0000 0000(00h):这个不应该作为第二个字节用。
    编程时序参考相应设备的DATASHEET。

“B”为1,两字节广播定义为“硬件广播”。主机在编程后,可以发送既定的从机地址到总线上,构成两字节序列的“硬件广播”。主机可能并不知道总线上从机的地址,它只能通过硬件广播的方式,将自身地址通知给系统。
硬件广播的第二个字节的前七位包括主机的地址。总线上的智能设备如微控制器,读取此地址并接收主机发送的其它信息。如果主机也可以作为从机使用,则以上读取的主机地址实际上也就是(切换主从模式后的)从机地址。在系统中,一种可能是系统复位后设备由主机发送模式切换到从机接收模式,这时由系统主机先告诉硬件主机数据应送往的从机地址,这样当硬件主机发送数据时就可以直接向指定从机(地址)发送数据了。
如下所示:

在这里插入图片描述
该过程操作也比较繁琐,最好的方式是记住每个设备地址,或者主机依次寻址127个从机地址,如果回复ACK说明设备存在,记录下设备地址即可。



http://chatgpt.dhexx.cn/article/wvHhqdZx.shtml

相关文章

I2C的理解

一:I2C是什么? 它就是为了让机器之间能够相互明白的一种通信协议,本质上所有的通信协议例如I2C,SPI,USART等与让人类相互交流的中文,英文等没区别。前者是让机器之间能相互理解,后者让人类相互理…

I2C总线

目录 一、简介 二、通讯协议 2.1、物理层 2.2、协议层 2.2.1、数据有效性规定 2.2.2、起始信号与停止信号 2.2.3、响应 2.2.4、总线的寻址方式 一、简介 I2C(Inter-Integrated Circuit):内部集成电路。由飞利浦公司开发的…

I2C接口总结

1 I2C总线的特点 I2C总线最主要的优点是其简单性和有效性。由于接口直接在组件之上,因此I2C总线占用的空间非常小,减少了电路板的空间和芯片管脚的数量,降低了互联成本。总线的长度可高达25英尺,通常最大频率为400Khz,…

关于I2C总线

两根线数据线SDA和时序线SCL,这让我想到了火线和零线。 总线上任何一个IC器件输出低电平都会使总线拉低,是线与的关系。 支持多主和主从工作方式 有效性:只有时钟线变成低电平数据线才能变化。 I2C的初始化应包括,起始信号&…

一篇短文让你彻底理解什么是I2C通信

一、I2C协议 I2C 也叫 IIC(Inter-Integrated Circuit)总线,是一种由PHILIPS公司在80年代开发的两线式串行总线,用于连接微控制器及其外围设备。它是半双工通信方式。 我们首先阅读以下这个例子,这会方便后…

I2C总线详解

1.1 I2C总线知识 1.1.1 I2C总线物理拓扑结构 I2C总线在物理连接上非常简单,分别由SDA(串行数据线)和SCL(串行时钟线)及上拉电阻组成。通信原理是通过对SCL和SDA线高低电平时序的控制,来产生I2C总线协议所需要的信号进行数据的传递。在总线空闲状态…

【i2c协议介绍】

文章目录 协议简单介绍五种速度模式master/slave和transmitter/receiver关系第一种情况:master作为transmitter,slave作为receiver第二种情况:当master作为receiver,slave作为transmitter i2c基本信号start产生stop信号数据传输有…

I2C详解(一)

I2C Bus(Inter-Integrated Circuit Bus) 最早是由Philips半导体(现被NXP收购)开发的两线时串行总线,常用于微控制器与外设之间的连接。要想了解详细I2C协议,目前最新的I2C标准协议是2014年第6版本,如下: I2…

I2C详细介绍

1、I2C总线具有两根双向信号线,一根是数据线SDA,另一根是时钟线SCL 2、IIC总线上可以挂很多设备:多个主设备,多个从设备(外围 设备)。上图中主设备是两个单片机,剩下的都是从设备。 3、多主机…

OLED显示屏I2C接口

简介 本文将介绍两种不同尺寸的OLED显示屏:0.96寸和0.91寸。他们都是4引脚I2C接口的,如下图所示: 注:经过项目测试发现,本文介绍的驱动方式和代码也完全适用于 1.54寸SSD1309主控的1.54寸OLED和1.29寸CH1115主控的OLE…

关于I2C接口的介绍

I 2C:Inter-Integrated Circuit 内部集成电路,应该翻译为集成电路总线,IC的正确读法为“I方C”。 这种通信协议由Philip最早提出,一种由数据线SDA和时钟线SCL两根信号线组成的串行通信总线,具体规范可以在NXP网站找到v2.1。不像UART没有CLOCK线,不能实现同步,I2C和SPI都…

【原创】【I2C】I2C介绍

一、这是个什么玩意 I2C首先它也是一个通信接口,同理通信接口就是用于模块之间的通信的,同SPI接口学习思路一样,首先明白它是一个接口,然后再扣它是一个怎么样的接口。 I2C(Inter-Integrated Circuit)总线是由Philips公…

I2C接口

一、I2C总线协议内容 1. I2C总线引脚定义 SDA (I2C数据引脚) CLK (I2C数据引脚) 2. I2C总线物理连接 I2C总线物理连接如下图所示,SDA和CLK连接线上连有两个上拉电阻,当总线空闲时,两根线均为高电平。连到总线上的任一器件输出的低电平&am…

“如何成为阿里云P8架构师?“ ”当然是考取阿里云新版ACE认证啊”

**简介:**阿里云新版云计算架构师ACE认证全面重构上线!为建立云计算生态领域含金量第一的专家级人才标准和认证体系,影响泛云生态高层次技术人才,阿里云历时一年,组织近百位专家,对云计算架构师ACE认证进行…

阿里云认证(ACA/ACP/ACE)的分类以及官网价格

阿里云认证分类: 阿里云认证分为三个等级,分别为初级(ACA)、中级(ACP)、高级(ACE) 下面还有很多的子分类 在子分类中,云计算是认证中最受欢迎的,无论是ACA云计算,还是ACP云计算,都…

阿里云ACA、ACP、ACE认证考试区别,报名入口及模拟试题分享

阿里云认证考试包含ACA、ACP、ACE三种认证类型,是阿里云针对不同产品类别、用户成长阶段、生态岗位,精心打造不同的认证考试。获得阿里云认证考试证书能够基于阿里云产品解决实际问题。获得更多阿里云生态下的就业机会。 助理工程师(ACA&…

成为阿里云架构师的进阶之路——阿里云首批ACE认证通过者逸疏专访

自2018年3月阿里云发布云计算架构师ACE(Alibaba Cloud Certified Expert,阿里云认证高级工程师)级别认证后,上线不到3个月,吸引了近百位业界优秀从业者参与考试。获得阿里云ACE认证,对于业界资深架构师来说,是自身实力的最好证明。 阿里云大学致力于培养云生态链路上的…

阿里云P8架构师|历时4个月1次通关ACE认证

李东是我在阿里云厂商这边了解到第一个自学通过ACE认证P8架构师,现将他学习考证记录分享给大家 写在前面: 我是来自阿里云数字政府行业线的解决方案架构师李东。 2022年3月28日阿里云发布了新版ACE(Alibaba Cloud Certified Expert - Cloud…

阿里云新版云计算架构师ACE认证专家解读会重磅来袭

简介:专家命题人非常解读 9600元全额代金券限量发放!活动钉群:31889256。 3月28日,阿里云新版云计算架构师ACE认证正式升级发布,面向云架构师、解决方案架构师、资深运维/交付等人群,提供技术能力认证。自升…

通过新版阿里ACE认证,实验操作题你来解一下

大家都知道了哈,阿里云新版ACE认证,现在是云认证界的塔尖位置,因为要成功拿到新版ACE认证,需要破关斩将,三个守门的将,分别是笔试,实验操作,以及面试 1,笔试 相对实验操…