打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
关于串口通信丢帧问题的处理

【一分钟聊嵌入式】力求精简,争取用一分钟左右的时间读完。每篇文章讨论一个嵌入式相关的话题,技术、职场、学习方法,或者一段程序等。有小伙伴想发表自己的观点,或想了解哪些内容,公众号后台留言即可。感谢关注!

本期话题

前两天有小伙伴在交流群里咨询:在串口通信的时候,如何应对其中一帧数据丢失或者干扰的情况吗?
之前分享过一篇如何设计通信接口协议的文章:如何编写通信接口协议。这篇文章侧重通信双方交互的数据格式。
本文来简单聊一聊,如何避免串口数据通信过程丢帧的问题。

聊一聊

看到这个问题,有很多大佬给出了自己的看法,列举几点:
  • 校验+确认,没收到确认包就重发
  • 加序号包,少了哪个序号就重发
  • 丢帧就只能软件加校验,硬件做好抗干扰
  • 从串口原理设计的弱点进行分析,电磁打扰?波特率?数据帧太多?线太长?等等。
  • ......
你怎么看这个问题呢?
接下来,根据我对题目的理解,来说几点处理措施,供参考。
首先说一下对题目的理解,我觉得这个问题的侧重点在于,串口通信丢帧(或干扰)问题已经发生了,该如何进行处理。
为了保证通信双方数据传输的可靠和正确性,我们一般会在硬件上做一些防止干扰的措施,同时在数据传输中添加校验等。接收端收到的数据校验不通过,则直接丢弃,不进行处理。
加了这些措施,主要是为了保证接收并处理正确的数据。如果数据传输出错,这一帧数据不就直接丢弃了吗?接下来该怎么办呢?
其实设备之间通信(不限于串口通信),都会设计数据通信协议,其中除了说明通信数据帧的格式之外,也会对出现丢帧情况如何处理进行说明,这样通信双方就按照这个规则进行处理。
串口通信,稳定可靠的通信机制一般是:一问一答的方式;即发送方发送数据之后,需要收到应答,才能确保数据发送成功并被正确处理。否则的话,发送方就认为传输出错,根据具体情况,进行重发。
为了能够确保数据发送与应答一一对应,可以通过在数据帧中添加帧序号的方法,确保每一帧数据的序号是唯一的,发送与应答的帧序号如果能够对应上,则说明应答帧接收到,可以进行后续处理。
如果出现丢帧问题,根据具体的应用场景,会有不同的处理措施:
(1)对于单指令控制场景
控制端发送指令数据给被控端,接收端没有接收到数据或者接收到的数据出错,则不会进行控制动作以及发送应答帧。
发送端一段时间内没有接收到指令应答,可以适当地进行指令重发。
(2)连续发送多个数据包的场景
这种场景,发送端可以给每一个数据包进行标号,同时接收端根据接收到的数据包序号进行处理,并给出应答数据包,其中应答数据包中可以携带期待的下一包数据的序号。
如果发送端的数据出错,则不会收到应答帧,可以进行重发当前帧。
如果接收端收到正确的数据帧,但是发送端收到的应答帧异常,则认为应答数据传输出错。发送端可以尝试进行重发当前帧,接收端在收到重复的数据包后,再重新发送相应的应答帧。
最后
这种一问一答的方式,虽然可以保证数据传输的可靠性。难免会存在传输效率低的问题。
如果发送的数据包比较多,可否等到数据包全部发送完成后,最后再统一进行校验处理呢?这种处理该如何做呢?
大家有兴趣可以思考一下。
提示:可以在数据包中添加序号,并且在第一个数据包中添加总共要发送的数据包个数。剩下的工作交给接收端进行处理。
先聊这些,如果你有更好的处理措施,欢迎一起探讨。
感谢阅读,加油~

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
一个数据包传送的奇怪有关问题
STP
协议——如何制作一个简易的串口通信协议
[z]一种基于状态机的串口通信协议的设计与实现
串口通信————UART、I2C、SPI详解(总结篇)
STM32串口通信详解
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服