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

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

3天内不再提示

如何使用数据包错误检查来保护您的温度读数

星星科技指导员 来源:ADI 作者:ADI 2023-02-13 10:48 次阅读

“数据包错误检查”(PEC)是一种在数据传输过程中广泛使用的错误检测机制。Maxim集成产品采用PEC模式,以提高数据传输的可靠性。本应用笔记讨论了PEC字节在具有1线和2线接口的温度传感器产品上的详细实现。

背景

通信无处不在,错误会导致通信效率下降。为了使沟通更准确,人们使用不同的方法来检测沟通错误。例如,在为网站登录创建新密码时,用户需要输入两次密码,以减少密码中出现拼写错误的机会。

当人们写银行路由号码等号码时,他们可能会犯错误。创建校验位是为了捕获这些转录错误。校验位是一种冗余校验,由算法从序列中的其他数字计算出的一个或多个数字组成。银行路由号码的最后一位数字是根据前八位数字计算的校验位,用于在交易过程中验证银行路由号码的真实性。

数据通信可能会出错,例如通道噪声、电气失真、随机位错误和串扰。循环冗余校验 (CRC) 是一种错误检测代码,用于检测数据传输中的意外错误。CRC用于多款具有1-Wire接口的Maxim温度传感器产品(即DS18B20、MAX31850)。部分产品带有 I®2C/SMBus兼容串行接口(即DS1862、MAX31875)以分组错误检查(PEC)的形式实现CRC,这是最初在SMBus中定义的机制。在数据传输系统中,可以在每个事务的末尾附加一个PEC字节作为错误检测代码。PEC 字节是根据多项式 C(X) = X 表示的 CRC-8 字节计算的8+ X2+ X1+ 1.PEC 机制提高了可靠性和通信鲁棒性,PEC 实现对于 SMBus 设备是可选的。

描述

每款1-Wire器件都有一个唯一的64位串行码存储在板载ROM中。当多个设备在同一总线上时,总线主站使用64位唯一ROM ID唯一标识总线上的每个从设备,这允许主站确定从设备的数量及其设备类型。当主设备想要与一个特定的从设备通信时,主机向总线上的设备发出命令,然后是目标设备的64位ROM代码序列,以寻址该特定的从设备。只有与64位ROM码序列完全匹配的从机才会响应主站发出的功能命令。

在1-Wire接口产品中,CRC字节作为64位ROM码的一部分(图1)和暂存器存储器的第9个字节(图2)提供。64位ROM码中的CRC字节是从ROM码的前56位计算得出的,其中包括序列号和家族代码。

暂存器内存中的 CRC 字节从暂存器的字节 0 到 7 计算得出,并在暂存器中的数据更改时更改。暂存器中的 CRC 字节是只读的。例如,为了从1-Wire温度传感器读取温度值,主机发出读取暂存器命令以读取暂存器,包括CRC字节。然后,主站从暂存器重新计算前八个数据字节的CRC字节,并将计算出的CRC字节与读取的CRC字节进行比较。如果它们匹配,则接收到的数据没有错误。

poYBAGPppO-ARxHLAAAQYd2YLno455.png?imgver=1

图1.64位1线ROM码。

pYYBAGPppPCAffPjAADfXMY7rYw088.png?imgver=1

图2.DS18B20暂存存储器。

对于我2支持PEC、CRC字节的C/SMBus组件可用于写入和读取。例如,MAX31875,一个微小的微功耗本地温度传感器,具有I2C/SMBus接口,支持可选PEC模式。

在写事务中,主机写入MAX31875的地址,等待MAX31875的ACK位,然后主机发送目标寄存器,然后发送MAX31875的另一个ACK位。主机写入两个数据字节,并从MAX31875接收每个数据字节的ACK位。PEC模式开启时,主机再发送一个CRC字节,并从MAX31875接收最后一个ACK位,停止交易。该CRC字节是使用从地址、寄存器地址和传输的数据计算的。

对于读事务,主机发送MAX31875的地址和目标寄存器地址,并从从机接收每次发送的ACK位。主机产生重复启动(Sr)字节,写入MAX31875地址和读位。MAX31875确认地址/读字节并发送两个数据字节。PEC模式开启时,数据传输后MAX31875附加一个PEC字节。CRC字节是使用具有写入位的从地址,寄存器地址,具有读取位的从地址以及传输的数据计算的。

poYBAGPppPKAEDGFAABw4ayjGB0363.png?imgver=1

图3.2字节写入MAX31875,PEC码。

pYYBAGPppPOAJU3aAACG5GvnnK4852.png?imgver=1

图4.SMBus 2 字节与 PEC 字节一起读取。

示例1:使用CRC进行1线读取

DS18B20是Maxim采用1-Wire接口的数字温度计之一。CRC字节作为DS18B20的64位ROM码的一部分和暂存器存储器的第9个字节提供。 DS18B20的ROM CRC字节采用48位序列号和8位家族码(28h)计算。表 1 中的示例使用序列号 04 16 74 8A 15 FF。

格式 CRC-8 (MSB) 序号 家庭代码
十六进制 72 04 16 74 8安 15 FF 28
二元的 0111 0010 0000 0100 0001 0110 0111 0100 1000 1010 0001 0101 1111 1111 0010 1000

为了计算CRC-8字节,主站使用多项式生成器,如图5所示。CRC发生器由移位寄存器和XOR门组成,所有移位寄存器位初始化为0。从ROM代码的最低有效位开始,一次将一位移入移位寄存器。从ROM移入第56位后,多项式发生器包含一个8位CRC值。

poYBAGPppPWAD7a5AACcZOxTCnA644.png?imgver=1

图5.用于 CRC 的 CRC 发生器 = X8+ X5+ X4+ 1.

有关示例 CRC 字节计算的更多详细信息

在此示例中,主站根据接收到的 8 位 ROM 代码计算 CRC-56 字节,从而产生值0x72。主机将计算出的CRC值(0x72)与存储在DS18B20的ROM (0x72)中的CRC字节进行比较,后者与计算值相同,并确认主站读数正确。

DS18B20的暂存存储器CRC字节使用暂存器中的字节0至字节7计算。有关暂存器内存内容的示例,请参阅表 2。

字节 8
CRC 字节
字节 7 字节 6 字节 5 字节 4 字节 3 字节 2 字节 1
温度 MSB
字节 0
温度 LSB
0 瓦 1 0 0 摄氏度 F F 7 % 1 8 1 字节 0 5 5 0
0000 0101 0001 0000 0000 1100 1111 1111 0111 1111 0001 1000 0001 1011 0000 0101 0101 0000

从暂存器中字节 0 的最低有效位 (LSB) 开始,一次一个位移入 CRC 发生器的移位寄存器。从暂存器移入第 0 位后,主机将05x8计算为 64 位 CRC 值。

主机将计算值 (0x05) 与暂存器 CRC 字节 (0x05) 进行比较。如果匹配,则大师确认暂存器中的读数正确。

示例 2:I2使用 PEC 编写 C/SMBus

温度阈值寄存器(T这) 用于设置MAX31875的温度限值。如果MAX31875测得的温度超过TOS,则配置寄存器显示过热状态。TOS 的上电状态为 80°C (0x5000),地址0x03。设置 T 的步骤这至95°C (0x5F00),主机写入MAX31875,如表3所示。

方向 M->S M->S M->S S->M M->S S->M M->S S->M M->S S->M M->S S->M M->S
内容 S 从地址 水利 一个 寄存器地址 一个 数据高 一个 数据低 一个 PEC 字节 一个 P
二元的 1001 000 0 0000 0011 0101 1111 0000 0000 0010 0100

主机使用图 8 所示的 PEC 生成器计算 PEC-6 字节。从从地址(MSB)的第一位开始,0x90035F00一次移入移位寄存器以计算0x24。

主机向MAX0发送90035x0024F31875并接收ACK,因为0x24与从机产生的PEC字节匹配。如果收到的PEC字节是匹配的,则从站向主站发送ACK。

pYYBAGPppPaAJ1WCAAChAlhjG0U963.png?imgver=1

图6.用于 CRC 的 PEC 发生器 = X8+ X2+ X1+ 1.

示例 3:I2带 PEC 的 C/SMBus 读取

将MAX31875分辨率设置为12位。LSB的值为0.0625°C。 PEC模式开启时,读取MAX31875的温度寄存器值(地址0x00)。MAX31875温度数据格式为16位,二进制补码,寄存器以2个字节读出:上字节和下字节。温度寄存器位 D[15:3] 包含温度数据。为了读取MAX31875的温度寄存器,主机通过写命令(0x90)发送从地址,接收ACK位,发送温度寄存器地址(0x00),并接收ACK位。继续重复启动,主机通过读命令(0x91)发送从地址,接收ACK位,MAX31875发回两个数据字节值,并附加一个PEC字节。

表4是MAX31875温度寄存器值23.00°C (0x1700)的主读数示例。

方向 M->S M->S M->S S->M M->S S->M ... M->S M->S M->S S->M S->M M->S S->M M->S S->M M->S M->S
内容 S 从地址 水利 一个 寄存器地址 一个 1 从地址 研发 一个 数据高 一个 数据低 一个 PEC 字节 N P
二元的 1001 000 0 0000 0011 1001 000 1 0001 0111 0000 0000 0101 1011

在读取操作期间,MAX31875向主机发送温度寄存器值(0x1700)和PEC字节(0x5B)。主站使用图 6 所示的 PEC 生成器计算 PEC 字节。从从地址的MSB开始,0x9000911700一次移入移位寄存器。主机将接收到的PEC字节与PEC发生器计算出的PEC字节进行比较,后者的值相同,并确认温度寄存器的读数正确。

结论

通过使用CRC或PEC,主站和从站可以验证接收到的数据并检测传输错误。特别是在多个设备同时连接同一主机的情况下,循环冗余检查提供了一种有效的错误检查方法。

审核编辑:郭婷

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

    关注

    2525

    文章

    48063

    浏览量

    739968
  • ROM
    ROM
    +关注

    关注

    4

    文章

    524

    浏览量

    84809
  • 总线
    +关注

    关注

    10

    文章

    2704

    浏览量

    87204
收藏 人收藏

    评论

    相关推荐

    求助 串口读数 ,解析数据包

    泄漏量符号;字节7所测得的泄漏量(高位);字节8所测得的泄漏量(低位);字节9标志位;字节100x0d;字节110x0a”只有帧尾(0d0a),没有帧头,我应该怎么解析数据包,确保能确保我读取11个字节的是一个完整的
    发表于 06-29 14:07

    请问SRIO每次出传输数据包的个数,数据包负载大小怎么设置?

    本帖最后由 一只耳朵怪 于 2018-6-19 14:25 编辑 DSP一次发送16个数据包,每个数据包256字节,一次传输4096个字节。如果现在DSP向FPGA发送2048字节数据,后面2048个字节它自动为零,造成效
    发表于 06-19 05:22

    如何用虚拟数据填充数据包

    如果主机要发送长度不为512倍的数据流,则最后一个不会自动提交给USB,因为它小于512字节。为了提交最后一个数据包,主机可以做两件事之一:它可以用虚拟数据
    发表于 12-28 15:24

    发送一个数据包,网络什么也看不到

    我已经编写了一些代码发送DHCCP发现。处理器是18F97 J60。PIC-WEB-EK板。我使用WireShark监控数据包。问题是:如果我发送一个
    发表于 05-24 14:53

    怎么跟踪每个连接间隔的数据包

    你好,我想知道是否有一种方法跟踪每个连接间隔发送的数据包的数量。实际使用一个延迟等于我的连接间隔的计时器计算我使用BLE堆栈API推送数据的次数。但我正在寻找其他解决方案。我需要这
    发表于 09-16 06:14

    引导加载程序拒绝发送数据和程序行数据包错误该怎么办?

    + bootloader_1_min_pkt_size)& gt;numberread))在bootloader_1 C绕线1744。如果有人能给我指出明显的错误我做了,我会很感激的。谢谢!这里是我的数据包生成器的完整代码:/ /发送命令包含一
    发表于 09-25 14:45

    zc706 SFP工作设计无法发送数据包该怎么办?

    的电脑发送任何数据包。我有wireshark检查传入的数据包,但仍然没有运气。我正在使用标准dma示例
    发表于 09-26 10:17

    uart引导加载程序数据包长度无效

    加载程序的例子。我修改的项目支持UART bootloader和它不工作。我收到以下错误:“引导程序报告错误数据包长度无效:数据包的长度不符合要求的
    发表于 09-26 12:21

    PIC32不能接收数据包

    。就像板没有收到任何数据包一样,我把ICMP服务器/客户端放在板上,这样我就可以告诉PIC32可以成功发送数据包,但是不能接收。我用调试器检查:从我的PC发送的包成功地生成了ISR。我发现在内存中修正了
    发表于 10-08 09:27

    怎样利用FPGA实现IPV6数据包的拆装?

    怎样利用FPGA实现IPV6数据包的拆装?IPV6数据包的包头和数据部分的拆分过程是怎样进行的?
    发表于 04-28 06:05

    怎样发送接收一个完整的数据包

    怎样发送接收一个完整的数据包
    发表于 12-09 06:52

    串口是怎样发送接收一个完整的数据包

    串口是怎样发送接收一个完整的数据包的?串口是如何根据接收超时判断一个数据包的?
    发表于 12-09 06:50

    如何设置LWIP的传入数据包大小使其可以接受大于16字节的数据包呢?

    错误并无限期挂起。如何设置传入数据包大小,使其可以接受大于 16 字节的数据包?请查看我的一些以太网配置的附件图片
    发表于 12-20 07:46

    如何发送音频/视频ISOC数据包

    我想开发带有音频和/或视频类的 USB 主机应用程序。是否有任何工作示例项目或代码片段?我检查了 STM32 HCD 驱动文件 - -ux_hcd_stam32_periodic_schedule.c,但它总是生成 EP_TYPE_INTR 数据包。如何发送音频/视频 I
    发表于 12-26 08:18

    如何使用数据包错误检查保护您的温度读数

    发表于 11-16 21:01 0次下载
    如何使用<b class='flag-5'>数据包</b><b class='flag-5'>错误</b><b class='flag-5'>检查</b>来<b class='flag-5'>保护</b>您的<b class='flag-5'>温度</b><b class='flag-5'>读数</b>