当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]通过I2C兼容接口读取ADC数据

本应用笔记讨论了通过I2C兼容接口读取多字节数据时需要特别注意的地方。介绍了每次读取一个字节时容易出现的问题,并给出了几个具体示例。本文也描述了进行数据传输的正确方法。

概述

I²C兼容2线接口是功能强大的总线机制,用于连接微控制器或微处理器与低速外设,例如:集成了模/数转换器(ADC)的外设。基于该总线的最基本的通信方式(即,写入/读取从机寄存器的一个字节)非常直观。但是,如果因为这种方法简单而掉以轻心,则会导致严重的系统错误。

 

单字节通道传送2字节数据

任何连接外设(尤其是传感器)的数字接口,都需要确保从器件的内部寄存器正确读取数据,尤其是在读取寄存器的过程中数据发生变化的情况下。数据传输过程中,如果ADC执行转换操作并更新寄存器的内容,数据则会发生改变。许多器件带有内部缓存器(通常不能从外部访问),用来存放最新转换结果。当I²C总线处于空闲状态时,更新所谓的“用户可访问”寄存器内容。

I²C协议每次只传送1个字节的数据。因此,如果有效数据字长超过8位,并且没有合理处置传输操作,则会引发问题。比如,MAX44000环境光传感器(ALS)的数据寄存器具有多达14位的数据(另有1位作为溢出标志,表示需要增加计数/亮度设置)。

表1. MAX44000 ALS数据寄存器

REGISTER B7 B6 B5 B4 B3 B2 B1 B0 REGISTER ADDRESS
ADC High Byte (ALS)   OFL
ALSDATA[13:8]
0x04
ADC Low Byte (ALS)
ALSDATA[7:0]
0x05

我们不能通过I²C直接读取所有数据ALSDATA[13:0],需要首先读取寄存器0x04的内容,然后读取寄存器0x05的内容,再把这些数据合并到一个至少16位的寄存器内。因此,在读取这些数据时需要特别谨慎。通过两次简单的单字节读操作(利用STOP (P)条件终止)完成数据读取,如图1所示。


图1. 单字节读操作

这种方法存在致命缺陷,确切地说,向器件发送STOP条件,返回“用户可见”的寄存器内容。由此,从寄存器0x04读取数据后,实际的14位数据可能在读取0x05寄存器之前已经更新。几种情形下,这种缺陷可能导致严重错误。

例如,当MAX44000环境光传感器处于10位、12位或14位模式时,亮度处于相对稳定状态,假设亮度在小范围波动,或许亮度正在缓慢上升,或周围存在少量噪声,使得0x04和0x05寄存器的14位数据计数值为255或256,考虑表2中的三种情形。

表2. 误差图示说明

State of Registers During
First Byte Read (Read 0x04 Only)
State of Registers During
Second Byte Read (Read 0x05 Only)
Result (14 Bit)

在后两种情形下,我们可能读到0或511,而不是读255或256,这是一个很严重的错误。发生这已错误的原因在于,第一次和第二次读操作之间,发出STOP状态后,寄存器0x04和0x05中的数据被更新。第一种出现问题情形下,第一个字节可以正确读出,但在读第二个字节时,总数为256的数据对应的最低位为零,因而,我们从器件中得到读数0;第二种出现问题的情形下,数据总计数值为256,由于在STOP状态发出后,第二个字节的数据在读取之前减少了1,所以显示为511,图2给出了多次读取数据时,这种故障的抽样情况。


图2. 多次采样时,实际读取单字节的数值

这个问题很容易通过一次读取2字节数据来避免,如图3所示。具体操作是,读取第一个数据字节后,发送REPEATED START (而不是STOP)进行操作,操作非常简单。通过读取2个字节,尽管在两个器件之间发送完全相同的位数,却可避免器件不恰当地更新I²C寄存器的内容。


图3. 2字节读操作示意图

上述示例适用于MAX44000和MAX44009,进行多次读操作时不会自动递增寄存器指针。器件功能各有差异,但工作原理相同。也可以将其很容易地扩展到N字节读取操作。应用笔记AN3588:“MAXQ2000微控制器软件I²C驱动”一文给出了几个C程序示例。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

ADC(Analog to Digital Converter, 模数转换器), 用于实现模拟信号向数字信号的转换。A/D转换的作用是将时间连续、幅值也连续的模拟信号(电信号)转换为时间离散、幅值也离散的数字信号(二进制...

关键字: ADC 转换原理 模拟信号

随着科技的飞速发展,电子产品在我们日常生活中扮演着越来越重要的角色。而在这些电子产品中,接口作为连接设备与外部设备的桥梁,其重要性不言而喻。其中,Type-C接口作为一种新型的接口标准,因其独特的优势,逐渐成为了众多电子...

关键字: 电子产品 Type-C 接口

一直以来,ADC模数转换器都是大家的关注焦点之一。因此针对大家的兴趣点所在,小编将为大家带来模数转换器的相关介绍,详细内容请看下文。

关键字: ADC 模数转换器

本款ADC具有高通道密度优势,可使CT模组达到更小像素,使CT扫描仪的成像质量达到较高的分辨率。

关键字: ADC

这款测试芯片是业界首款采用12纳米FinFet(FF)技术为音频IP提供完整解决方案的产品。该芯片完美结合了高性能、低功耗和优化的占板面积,为电池供电应用提供卓越的音质与功能。这款专用测试芯片通过加快产品上市进程、提供同...

关键字: 测试芯片 半导体 ADC

74LS175是一款4D触发器集成电路,它包含6个D触发器,这些触发器可以组合起来形成寄存器或抢答器等多种功能部件。

关键字: 74ls175 触发器 寄存器

2024年1月23日,鼎阳科技正式发布8GHz带宽高分辨率示波器,树立了国产高分辨率示波器的新标杆。此次发布的示波器为SDS7000A系列推出的新型号SDS7804A,具备12-bit高精度ADC,1Gpts存储深度,支...

关键字: 示波器 ADC 第三代半导体

单片机复位电路的作用是:使单片机恢复到起始状态,让单片机的程序从头开始执行,运行时钟处于稳定状态、各种寄存器、端口处于初始化状态等等。

关键字: 复位电路 单片机 寄存器

SCL(serial clock):时钟线,传输CLK信号,一般是I2C主设备向从设备提供时钟的通道。

关键字: I2C 总线通信 时钟线

随着电动汽车的普及,充电桩作为电动汽车的重要基础设施,越来越受到人们的关注。然而,对于许多电动汽车用户来说,直流充电桩和交流充电桩的接口和区别仍然是一个令人困惑的问题。本文将从接口和区别两个方面,详细探讨直流充电桩和交流...

关键字: 电动汽车 接口 充电桩
关闭
关闭