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

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

3天内不再提示

关于从I²C接口上的ADC读取数据

星星科技指导员 来源:ADI 作者:ADI 2023-04-04 10:59 次阅读

本应用笔记讨论了通过I²C兼容接口读取多字节数据时需要注意的问题。讨论了一次读取一个字节的陷阱,并提供了一些具体示例。本文还介绍了处理此类数据传输的正确方法。

介绍

I²C兼容的双线接口是一种强大的机制,用于将微控制器微处理器连接到低速外设,例如带有集成模数转换器ADC)的外设。通过该总线进行通信的最基本形式(即一次从从站寄存器写入/读取单个字节)非常简单。但是,为了简单起见,将自己限制在这种方法上有一些陷阱。

通过 2 字节通道传输 1 字节数据

与外设(尤其是传感器)的任何其他数字接口一样,我们需要从设备的内部寄存器中读取正确的数据。当寄存器中的数据在读取过程中发生变化时,这一点尤其重要。如果ADC在数据传输时运行转换或更新寄存器,则数据可能会发生变化。许多设备都有一个内部缓冲区(通常无法从外部访问),其中包含最新的转换结果。当没有I²C活动时,该器件使用新数据更新所谓的“客户可访问”寄存器。

I²C协议一次传输1字节的数据。因此,如果感兴趣的数据总量超过 8 位并且传输处理不当,则可能会出现问题。例如,MAX44000的环境光传感器(ALS)数据寄存器可以有多达14位数据(加上1位表示溢出,这意味着应增加计数/勒克斯设置)。

注册 B7 B6 B5 B4 B3 B2 B1 B0 注册地址
ADC 高字节 (ALS) 奥福 数据[13:8] 0x04
模数转换器低字节 (ALS) 数据[7:0] 0x05

我们无法通过I²C直接读取所有ALSDATA[13:0],因此我们必须首先读取寄存器0x04的内容,然后读取寄存器0x05的内容,并在至少16位寄存器中连接数据。但是,我们必须注意如何读取这些数据。可以简单地执行两个由STOP(P)条件终止的单次读取,如图1所示。

pYYBAGQrkpSAJO48AAAWYOXbvV4777.gif

图1.单字节读取。

这种方法有一个致命的缺陷。具体而言,发送 STOP 条件会向设备发出信号,以返回更新“客户可见”寄存器。因此,在从寄存器0x04获取数据后,实际上可以在读取寄存器14x0之前更新05位数据。在某些情况下,此缺陷可能会造成灾难性后果。

例如,如果光照水平处于一定水平,MAX44000环境光传感器处于10位、12位或14位模式。假设电平徘徊在一个区域中,因此寄存器14x0和04x0中的05位将处于255或256个总数,这可能是由于缓慢增加的光或一些少量的噪声。考虑表 2 中的三种情况。

第一个字节读取期间
的寄存器状态(仅限读0x04)
第二次字节读取期间
的寄存器状态(仅限读0x05)
结果(14 位)
poYBAGQrkpWAOmnaAAAEWPC33p8632.gif pYYBAGQrkpaAcREKAAAES8vwA3Y844.gif pYYBAGQrkpeAQoJVAAABziD1l-g926.gif
poYBAGQrkpiAW2W5AAAERG3-Z6g736.gif pYYBAGQrkpmAP3-kAAAEW7w9SAU568.gif poYBAGQrkpmAbGvYAAABdRoRHHc702.gif
pYYBAGQrkpqAFjt1AAAEaZ-5wto572.gif poYBAGQrkpuAKN9IAAAEMXNce0U925.gif pYYBAGQrkpuALE2IAAABrm1kqiE760.gif

在最后两种情况下,我们不是读取 255 或 256,而是读取 0 或 511。这是一个巨大的问题。发生这种情况是因为寄存器中的数据在发送 STOP 条件后,在第一次和第二次读取之间0x04和0x05更新。在第一种有问题的情况下,第一个字节被正确读取。但是当读取第二个字节时,数据总共读取了 256 个计数,其中最低字节为零。因此,我们从设备中获得了零读数。在第二个问题情况下,数据也是总共256个计数。这似乎变成了 511 个计数,因为在发送 STOP 条件后但在读取第二个字节之前,数据减少了一个计数。有关在多次读取中发生这种情况的次数的示例,请参见图 2。

poYBAGQrkpyAe_QMAAAVDNy6OyE646.gif

图2.单字节读取多个样本的实际读数。

通过一次读取 2 个字节可以轻松避免此问题,如图 3 所示。这是通过在读取第一个数据字节后发送 REPEAT START 而不是 STOP 条件来完成的,并且实现起来相当简单。通过读取2个字节,我们可以防止器件执行更多的I²C寄存器更新,即使我们在两个器件之间发送相同数量的位。

pYYBAGQrkp2AFYZCAAATRihzZK0787.gif

图3.2 字节读取的图示。

上述示例适用于MAX44000和MAX44009,它们在进行多次读取时不会自动递增寄存器指针。您的设备可能行为不同,但原理始终相同。这很容易扩展到读取 N 个字节。

审核编辑:郭婷

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

    关注

    2545

    文章

    50438

    浏览量

    750936
  • 寄存器
    +关注

    关注

    31

    文章

    5290

    浏览量

    119792
  • adc
    adc
    +关注

    关注

    98

    文章

    6388

    浏览量

    543728
收藏 人收藏

    评论

    相关推荐

    HDMI信号在Type-c接口上是如何分配的?

    关于Type-c 传输HDMI是否有相关案例,资料提供?HDMI信号在Type-c接口上是如何分配的?
    发表于 02-29 08:28

    如何将CubeMX LSM303AH连接到I2C接口上呢?

    如何将CubeMX LSM303AH连接到I2C接口上呢?求大神告知
    发表于 12-16 06:44

    I2C总线接口模块设计

    本实验是基于EasyFPGA030的I2C总线接口模块设计,用EasyFPGA030开发套件通过I2C协议实现对二线制I2C串行EEPROM的读写操作,先把
    发表于 11-02 17:01 41次下载

    基于ADJC702x的I2C总线接口设计

    阐明了 I2C总线 的特性,以基于ARM7TDMI 体系结构的新型ADC702x 系列MicroConverter ADC7020 为例子,介绍了内带I2C
    发表于 06-07 16:56 24次下载
    基于ADJC702x的<b class='flag-5'>I2C</b>总线<b class='flag-5'>接口</b>设计

    通过I2C兼容接口读取ADC数据

    本应用笔记讨论了通过I2C兼容接口读取多字节数据时需要特别注意的地方。介绍了每次读取一个字节时容易出现的问题,并给出了几个具体示例。本文也描
    发表于 08-26 22:13 874次阅读
    通过<b class='flag-5'>I2C</b>兼容<b class='flag-5'>接口</b><b class='flag-5'>读取</b><b class='flag-5'>ADC</b><b class='flag-5'>数据</b>

    MPU6050+I2C读取数据+-精简版

    MPU6050+I2C读取数据+-精简版 值得学习
    发表于 11-03 10:28 0次下载

    mpu6050对应i2c地址是什么_如何读取数据

    本文主要介绍了mpu6050对应i2c地址是什么,并通过stm32的硬件读取mpu6050的数据。MPU6050 的 I2C 地址是 0xD0H(11010000B)。
    发表于 12-11 16:04 2.5w次阅读
    mpu6050对应<b class='flag-5'>i2c</b>地址是什么_如何<b class='flag-5'>读取</b><b class='flag-5'>数据</b>

    如何ADC通道读取模拟输入信号

    将以上草图上传到Uno32板上,然后MPIDE打开串行终端窗口。 ADC样本(整数ADC输出)以1秒的间隔打印在窗口上。您可以观察这些数字如何随着LDR上光线的变化而变化。如果您将手
    的头像 发表于 12-05 16:59 8330次阅读
    如何<b class='flag-5'>从</b>其<b class='flag-5'>ADC</b>通道<b class='flag-5'>读取</b>模拟输入信号

    LTC2481:带Easy Drive输入电流抵消和I²C接口的16位Delta Sigma ADC数据

    LTC2481:带Easy Drive输入电流抵消和I²C接口的16位Delta Sigma ADC数据
    发表于 05-24 15:29 162次下载
    LTC2481:带Easy Drive输入电流抵消和<b class='flag-5'>I</b>²<b class='flag-5'>C</b><b class='flag-5'>接口</b>的16位Delta Sigma <b class='flag-5'>ADC</b><b class='flag-5'>数据</b>表

    APM32F030C8T6_ADC_ADC Vref参考电压数值读取出错

    APM32F030C8T6_ADC_ADC Vref参考电压数值读取出错
    发表于 11-09 21:04 2次下载
    APM32F030<b class='flag-5'>C8T6_ADC_ADC</b> Vref参考电压数值<b class='flag-5'>读取</b>出错

    FPGA与ADC数字数据输出的接口

    本文讨论了标准接口 — SPI、I2C、SPORT、LVDS 和 JESD204A——用于将 FPGA 连接到 ADC。随着数据速率的进一步提高,FPGA与
    的头像 发表于 12-21 10:57 7371次阅读
    FPGA与<b class='flag-5'>ADC</b>数字<b class='flag-5'>数据</b>输出的<b class='flag-5'>接口</b>

    关于I²C接口上ADC读取数据及处理方法

    本应用笔记讨论了通过I²C兼容接口读取多字节数据时需要注意的问题。讨论了一次读取一个字节的陷阱,
    的头像 发表于 01-29 15:53 1949次阅读
    <b class='flag-5'>关于</b><b class='flag-5'>从</b><b class='flag-5'>I</b>²<b class='flag-5'>C</b><b class='flag-5'>接口上</b>的<b class='flag-5'>ADC</b><b class='flag-5'>读取</b><b class='flag-5'>数据</b>及处理方法

    I2CI3C关于功耗和传输速率的对比

    I2CI3C 关于功耗和传输速率的对比: I3C 使用推挽功能的双线串行接口,速度可达 12.5 MHz
    的头像 发表于 07-22 16:24 1750次阅读
    <b class='flag-5'>I2C</b>和<b class='flag-5'>I3C</b><b class='flag-5'>关于</b>功耗和传输速率的对比

    什么是I3C接口 I3C和SPI接口有什么区别

    I3C接口使用两根通信线,一根是数据线(SDL),另一根是时钟线(SCL)。与I2C总线一样,I3C接口
    的头像 发表于 03-05 16:50 2586次阅读
    什么是<b class='flag-5'>I3C</b><b class='flag-5'>接口</b> <b class='flag-5'>I3C</b>和SPI<b class='flag-5'>接口</b>有什么区别

    TLA2528小型8通道12位ADC,具有I2C接口GPIO数据

    电子发烧友网站提供《TLA2528小型8通道12位ADC,具有I2C接口GPIO数据表.pdf》资料免费下载
    发表于 07-26 11:17 0次下载
    TLA2528小型8通道12位<b class='flag-5'>ADC</b>,具有<b class='flag-5'>I2C</b><b class='flag-5'>接口</b>GPIO<b class='flag-5'>数据</b>表