I2C通讯不了?是不是硬件有问题?

发布时间:2024-03-28  

我们经常会遇到各种各样的问题,一些通信接口也会出现,自然也不例外。假如遇到没反应,那么可能会出现这种情况:软件工程师说,我软件都已经配好了,但是就是读写不到数据,是不是有问题”。

本文引用地址:

这个时候,就需要我们了解的通信时序,我们可以通过示波器抓取通信的波形,看是否满足通信时序要求,主机有没有发送数据?I2C通信地址对不对?如果主机有发送数据,从机是否有正常应答?通信信号质量是否OK?如此这般,一般是能够查到问题在哪里的。

基于上面的问题,这会要求我们掌握I2C的通信时序。毕竟,你只有知道它是长什么样子,你才能知道它对不对下面就简单介绍下I2C的通信时序。

概述

I2C总线是一种十分流行并且强大的总线,其多用于一个主机(或多个)与单个或多个从设备的场景。图1表明了多种不同的外设可以共享这种只需要两根线便可以连接到处理器的总线,相对于其他接口来说,这也是I2C总线可以提供的最大优势之一。

这篇应用笔记的目标是帮助用户理解I2C总线是如何工作的。

图1展示了一个典型的用于嵌入式系统中的I2C总线,其上挂载了多种从设备。作为I2C主机的从微控制器控制着IO拓展、不同传感器、EEPROM、多个ADC/多个DAC、等等。所有这些设备只需要通过来自主机的两根引脚来控制。

640-2.png

电特性

I2C总线使用开漏输出控制器,在同一线路上带有一个输入缓冲器,这样便可以允许在单根数据线上实现双向数据流传输。

用于双向的开漏极

漏输出极允许将总线上的电压拉低(大多数情况下是到地),或释放总线以允许其被上拉电阻拉高。当总线被主机或从机释放,线上的上拉电阻负责将线上电压上拉到电源由于并没有设备可以在总线上输出高电平,这也就意味着总线在中,将不会碰到一个设备输出高,而另一个设备试图输出低所导致的短路问题(电源轨到地)。I2C总线要求处于多主机环境下的单个主机在输出高而读回的实际总线电平为低时(这意味着另一个设备拉低了它)中止通讯,因为另一个设备正在使用总线。采用推挽输出方式的接口就没有这么自由了,这也正是I2C总线的一个优势

640-3.png

图2展示了位于SDA/SCL线上的主从设备的内部简化结构,其由一个用于读取数据的缓冲器,以及一个用于发送数据的下拉场效应管组成。一个设备只被允许拉低总线(规定为短路到地)或释放总线(对地呈现高阻态)以允许上拉电阻拉升总线电平。当处理I2C设备时,有一个重要的概念需要阐明:没有设备可以保持总线为高这个特性使得双向通讯得以实现。

开漏极拉低

正如前面章节所述,开漏输出只能将总线拉低,或者释放总线然后依靠上拉电阻拉高总线。图3展示了总线拉低时的电流流向。当逻辑电路想要发送一个低电平时,其会使能下拉场效应管,场效应管会通过短路到地的方式拉低线路。

640-4.png

开漏极释放总线

当从机或主机想要传输一个逻辑电平高,它只能通过使能场效应管的方式释放总线。这将会使得总线处于浮空状态,同时上拉电阻将会将总线电平拉高到供电轨,此电平被当作高电平看待。图4展示了电流如何流过用于拉高总线的上拉电阻。

640-5.png

I2C接口

I2C的常用操作

I2C总线是一种双向接口,其使用被称为主机的控制器与从设备进行通讯。从机不会主动传输任何数据,除非其被主机寻址。每个处于I2C总线上的设备均有独有的设备地址,以用于与位于同一总线上的其他设备做区分。很多从机需要在启动后进行配置以设置设备行为。这通常在主机访问从机的内部寄存器映射时完成,这些寄存器均有独一无二的寄存器地址单个设备可以具有一个或多个寄存器,这些寄存器可以用来存储或读写数据

I2C总线的物理接口由串行时钟线(SCL)和串行数据线(SDA)组成。SCL和SDA均需要通过上拉电阻连接到Vcc上拉电阻的大小由I2C线路上的等效电容大小决定(想要了解更多,可以参考TI的I2C Pull-up Resistor Calculation这份文档,文档号:SLVA689)数据传送只能在总线空闲时初始化如果SDA和SCL在一个STOP标志后均处于高电平状态,这时可以认为总线处在空闲状态。

主机访问从机的大体流程如下所示

1、假设一个主机想要向从机发送数据:

a、发送方主机发送一个START标志并且寻址接收方从机

b、发送方主机发送数据到接收方从机

c、发送方主机通过发送STOP标志结束传输

2、如果主机想要从从机接收/读取数据:

a、接收方主机发送START标志并寻址发送方从机

b、接收方主机发送需要读取的寄存器地址到发送方从机

c、接收方主机从发送方从机接收数据

d、接收方主机通过发送STOP标志结束通讯

START与STOP标志

主机可以通过发送START标志初始化与设备的I2C通讯,或者发送STOP标志结束通讯。当SCL处于高电平时,SDA上的下降沿意味着一个START标志,而SDA上的上升沿意味着一个STOP标志。

640-6.png

重复的START标志

重复的START标志与通常的START标志作用类似,其用于STOP标志后紧接START标志的情况时,用于代替这两者。它看上去与START标志一致,但是与START标志不同的是,重复的START标志在STOP标志之前出现(也就是总线不处于空闲状态时)。当主机希望开始一次新的通讯,但又不希望发送STOP标志使总线进入空闲状态时这会非常管用,这样可以防止当前主机的总线控制权被其他主机抢夺(当处于多主机环境下)

数据有效性与字节格式

数据位伴随着SCL上的每一个时钟脉冲被传输。单个字节由SDA线上的8位数据组成,其可以是设备地址、寄存器地址或者读自/写入设备的数据。数据以大端在前(MSB)的方式传输。在START标志与STOP标志之间可以传输任意数量的数据字节。SDA线上的数据必须在时钟电平为高时保持稳定,因为SCL线为高时,SDA线上的变动将会被当作控制指令(START或STOP)。

640-7.png

应答(ACK)和非应答(NACK)

数据的每一字节(包括地址字节)后总是伴随着来自接收方的1位ACK位。ACK位使得接收方可以告知发送方当前字节已成功接收,并且可以发送下一字节。

在接收方发送ACK位前,发送方必须释放总线。接收方通过在ACK/NACK时钟周期(第9时钟周期)的低电平相位拉低SDA线来发送一个ACK位,如此一来,SDA线将会在ACK/NACK时钟周期的高电平相位保持为低电平。设置与保持时间必须着重注意。

如果SDA线在ACK/NACK时钟周期保持为高电平,这将会被作为NACK。有好几种状态将会导致NACK的产生:

1、接收方无法进行接收或发送,因为其正在执行一些实时性功能(real-time function),无法与主机进行通讯。

2、在发送期间,接收方收到了无法识别的数据或指令。

3、在发送期间,接收方无法接收更多数据字节(也就是缓冲区满了)。

4、作为接收方的主机完成了数据读取,因此通过发送一个NACK通知从机。

640-8.png

I2C总线数据

数据可以写入/读自从机,但是这是通过读写从设备内部的寄存器完成的。

包含信息的寄存器处于从机的内存中,无论这些信息是配置信息还是一些需要回发给主机的采样数据。为了指示从机去执行某一任务,主机必须向这些寄存器内写入信息。

虽然通常来说I2C从机是具有多个寄存器的,但也需要注意并不是所有从机都是这样。对于一个只具有单个寄存器的简易从机来说,可以通过在从机地址后直接发送数据的方式来直接写这个单一的寄存器,而不需要再对寄存器进行寻址。一个通过I2C总线控制的8位I2C开关可以很好的作为单寄存器设备的例子。由于它通过1位来使能/失能一个通道,因此只需要1个寄存器,主机可以在从机地址后直接写入寄存器数据,跳过寄存器编码部分。

写位于I2C总线上的从机

要在I2C总线上执行写操作,主机会发送一个START标志以及从机地址到总线上,并且将最后1位(读写位)设为0以表明这是写操作当从机发送应答位之后,主机便发送希望写入的寄存器地址。从机再一次应答,通知主机从机已准备好。这之后,主机开始发送寄存器数据到从机。当主机发送完所有需要发送的数据(有时只是一个字节),其将会通过发送STOP标志结束通讯。

图8展示了一个写入单个字节到从机寄存器的例子。

640-9.png

读位于I2C总线上的从机

从从机读取数据与写入数据类似,但是有一些额外的步骤。

为了读取从机,主机必须先指示从机自己想要读取哪个寄存器。这一步通过执行与写操作类似的开始通讯步骤完成,发送读写位为0的设备地址(意味着一次写操作),紧跟着希望读的寄存器的地址。一旦从机应答了此地址,主机将会再一次发送START标志,并发送读写位为1的设备地址(意味着一次读操作)。这时,从机将会应答读请求,同时主机释放总线但是保持到从机的时钟供应。在通讯流程的这一部分,主机将会作为接收方主机,同时从机将会作为发送方从机。

主机将会继续发送时钟脉冲,但是会释放SDA线以便于从机传输数据。在每个字节数据的结尾,主机将会发送一个ACK到从机,让从机知道主机准备好接收更多的数据。一旦主机接收完成期待的字节数量,它将会发送一个NACK,通知从机终止通讯并要求从机释放总线。紧接着主机将会发送一个STOP标志结束通讯。

图9展示了从从机寄存器读取单个字节的例子。

640-10.png

免责声明:本号对所有原创、转载文章的陈述与观点均保持中立,推送文章仅供读者学习和交流。文章、图片等版权归原作者享有,如有侵权,联系删除。

文章来源于:电子产品世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    是指将数字信号转换为模拟信号,主要用于恢复模拟信号或进行模拟控制。 十三、DAC0832器件有哪些主要技术指标?其含义是什么? 答:DAC0832是将数字信号转换为模拟信号的器件。它的主要技术指标及含义如下:分辨率:8 位,可以......
    系统。 电力传输:供电网络、电力线载波通信、超级充电站等。 那市面上都有哪些浮地示波器值得推荐呢?领先的示波器厂家如泰克科技、是德、罗德与施瓦茨、法国CA公司以及电力行业的大玩家福禄克,都有......
    关于手持式频谱仪的问题解答;手持式频谱分析仪 Q1如何用虹科Spectrum Manager添加GPS信息到频谱曲线的报告中?需要哪些第三方工具? 将GPS 坐标附加到SCC文件有两种方式: 可以......
    锂电池充电管理芯片常见的有哪些?保护功能体现在哪些方面?; 常见的有哪些?最近几年磷酸铁开始被广泛使用,一些产品对电池容量的需求不断提升,就需要串联多个,于是就催生出了锂电池。锂电......
    鸿蒙系统怎么样?有哪些特点?; ,作为华为推出的全新,一经发布就引起了广泛的关注。它的出现不仅代表了华为在技术领域的突破,也象征着操作系统市场即将迎来新的变革。那么,鸿蒙系统究竟怎么样?它有哪些......
    机器视觉方法有哪些类型 机器视觉的基本功能包括哪些方面;机器视觉方法有哪些类型 机器视觉方法可以根据其特点和应用领域进行分类。下面是几种常见的机器视觉方法类型: 1. 特征提取与描述子方法:这种......
    电路设计,常用的软件有哪些?;1、前言 硬件电路的设计主要分为3个部分本文引用地址:1、原理图设计 2、PCB设计 3、物料清单(BOM)表制作 原理图设计就是将项目功能需求,转化......
    示波器软件该如何选择,有哪些方面需要注意?;在整个电子行业中示波器无疑是最为重要的仪器,无论是电子测试还是电子计量,只要涉及到电气信号的试验中就必定会有示波器。随着如今电测行业智能化、自动......
    销售官Charles Thooris共同参与,讨论了这些安全趋势如何影响系统和应用设计决策,以及有哪些解决方案可以帮助确保它们能够应对不断变化的环境。   后量子加密和未来的方向 尽管PQC的方法尚未成熟,但它......
    知道只所以这样设计是有其必然的道理的! 问题三: 当我们反激的占空比大于50%会带来什么? 好的方面有哪些? 不好的方面有哪些......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>