STM32 CAN通信自定义数据包多帧连发乱序问题

场景:

can标准帧中每一帧只能传输8字节,而应用中传输一包的内容往往超过8字节,因此需要把一个包拆成多个帧发送,接收端才把收到的多帧重新组装成一个完整的包


问题描述

在一问一答的两块板间通信,多帧连发是能够按照顺序发送的。但是,在一个主板和多个从板之间轮询一问一答的通信中,偶尔出现持续一段时间或者长时间无法通信的情况,特别高帧率发送的情况下,几乎无法通信。

原因分析:

抓取can总线数据发现不同板之间的帧相互交叉乱序,导致接收到的包因为乱序无法还原。但是不能保证多帧连续发送的话,就会导致无法还原包。如图,7E和E7之间为一包,但其出现乱序
在这里插入图片描述
发送过程大致为

  1. 把包根据8字节拆分为多个帧
  2. 调用发送函数HAL_CAN_AddTxMessage塞第一帧进发送邮箱,id为本设备ID
  3. can自动从邮箱里面取出该帧发送
  4. 发送完毕触发邮箱发送完毕中断,在中断里面再调用HAL_CAN_AddTxMessage塞下一帧进发送邮箱,ID为0,以最高优先级占用CAN总线,循环直到最后一帧
    以上过程按道理很快就可以连续发送,但是就是会出现不连续的情况。因为采用的轮询方式,很难保证其他can总线的设备不也在同时在竞争can总线,在发送完毕进入中断塞数据进邮箱的空隙,尽管ID号是0,但是在竞争总线的时刻,还在中断里面塞数据进邮箱,并未参与can总线竞争,就会被其他的设备竞争掉总线了,待填充完邮箱,因为ID号为0,其又可以占用can进行发送,就出现了本设备的帧和其他设备的帧交叉了。

解决方案:

其原因就是发送中出现时间停顿,让其他can设备有了可乘之机,因此保证多帧之间在上一帧发送完毕立马竞争总线进入下一帧发送就可以保证该包是连续发送的。以下是我的改进:

  1. 开启邮箱按照填写顺序发送(而不是根据邮箱ID优先级发送)
  2. 一包多帧的数据持续塞满三个邮箱,确保多帧发送过程中没有出现三个邮箱都出现空的情况
    在裸机的时候,其可以连续高帧率发送不出现乱帧,但是开启FREERTOS后,还会出现乱帧的情况,其原因是can的发送中断被freertos管理,需要把use freertos function关掉,使用裸机的中断,我把其优先级设为1.
    在这里插入图片描述
    但是!还是有但是!我的freertos任务多了以后,还是出现乱帧的情况,检查后发送,我的第一次填写邮箱是在代码里面进行的,也就是说我塞邮箱的过程中,freertos会打断我塞数据的过程,导致有概率不是连续塞数据进去邮箱的。如图,虽然我在代码调用的发送中断函数,但是其程序指针运行在psp下,而不是msp下,优先级就是普通的freerto任务,自然不能保证以高优先级连续塞数据进发送邮箱了。
    在这里插入图片描述
    改进为如下,分包好后,通过HAL_NVIC_SetPendingIRQ追加一个发送中断,其不会执行发送过程就可以直接触发发送中断,这下子没其他东西在打扰塞满发送邮箱了吧!
    在这里插入图片描述

总结:

经过测试,can总线每秒8000帧数据的情况下,有10%的错误率,检查后发现,顺序没乱,有些帧没能发送来就丢弃了,因为我设置的发送失败不重发。降低速率至6000,1%内的错误率,帧没发出现的数量大幅度下降,证明还是太快了。设置3000,0%错误率,为什么3000就是0%呢,看了一下can总线,发送我的每一包发送需要时间是1ms,一包大概3帧,也就是1s上限差不多是3000多帧。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/209524.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

易点易动设备管理系统提升设备能耗管理和设备状态监控效率

如今,能源效率和设备状态监控对于企业来说变得越发重要。传统的设备管理方式往往存在能耗浪费和难以实时监控设备状态的问题。为了解决这些问题,易点易动设备管理系统应运而生。本文将介绍易点易动设备管理系统的功能和优势,以及如何通过它提…

低压配电柜浪涌保护器综合选型方案

地凯科技低压配电柜是指在额定电压不超过1000V的交流电力系统中,用于接受和分配电能,控制、保护和监测电路的装置。低压配电柜广泛应用于工业、商业、住宅等领域,是电力系统的重要组成部分。 然而,低压配电柜也面临着来自外部和内…

UniApp打包教程:使用HBuilder X和AppUploader完成原生App云打包和上架指南

UniApp打包教程:使用HBuilder X和AppUploader完成原生App云打包和上架指南" 目录 uniapp进行打包 使用上架工具appuplode进行发包 1.登录appuploder软件 2.登陆开发者App Store后台 uniapp进行打包 在HBuilder X编辑器中打开需要打包的项目,然后…

SpringCache使用详解

SpringCache 1.新建测试项目SpringCache2.SpringCache整合redis2.1.Cacheable2.2.CacheEvict2.3.Cacheput2.4.Caching2.5.CacheConfig 3.SpringCache问题4.SpringCache实现多级缓存 1.新建测试项目SpringCache 引入依赖 <dependencies><dependency><groupId&g…

【文末送书】十大排序算法C++实现

欢迎关注博主 Mindtechnist 或加入【智能科技社区】一起学习和分享Linux、C、C、Python、Matlab&#xff0c;机器人运动控制、多机器人协作&#xff0c;智能优化算法&#xff0c;滤波估计、多传感器信息融合&#xff0c;机器学习&#xff0c;人工智能等相关领域的知识和技术。关…

2023 年亚马逊黑色星期五和网络星期一的企业电子商务指南

亚马逊黑色星期五和网络星期一 周末即将到来&#xff01;感恩节于 11 月 23 日举行&#xff0c;紧接着是 24 日黑色星期五和 27 日网络星期一。您的亚马逊业务准备好应对大量涌入了吗&#xff1f; 我们相信您已经准备好黑色星期五优惠并准备好库存&#xff0c;以确保您有足够的…

【Python基础】多进程编程(进程间通信 、进程池等附上实例代码)

&#x1f308;欢迎来到Python专栏 &#x1f64b;&#x1f3fe;‍♀️作者介绍&#xff1a;前PLA队员 目前是一名普通本科大三的软件工程专业学生 &#x1f30f;IP坐标&#xff1a;湖北武汉 &#x1f349; 目前技术栈&#xff1a;C/C、Linux系统编程、计算机网络、数据结构、Mys…

什么牌子首饰超声波清洗机好、家用首饰清洗机推荐

精致的男生女生在搭配衣服肯定是少不了首饰的点缀的&#xff0c;像项链、戒指、耳环等这种配饰是少不了的&#xff0c;我们日常生活中清洗首饰的方法有很多&#xff0c;有的是用盐水清洗&#xff0c;有的是用苏打水清洗&#xff0c;虽然清洗方法有非常多&#xff0c;但是都不及…

c#数据库:vs2022 加入mysql数据源

网上有VS2019连接MySQL数据库的&#xff0c;那么VS2022&#xff0c;VS2023如果和连接到mysql数据库呢&#xff0c;这里总结一下我的经历&#xff1a; 1、首先下载ODBC驱动安装包 当前下载地址&#xff1a;https://dev.mysql.com/downloads/connector/odbc/ 2、ODBC安装 下载完…

【搜维尔科技】产品推荐:Virtuose 6D RV,大型工作空间触觉设备

Virtuose 6D RV为一款具有大工作空间并在所有6自由度上提供力反馈的触觉设备&#xff0c;设计专用于虚拟现实环境&#xff0c;特别适合于大型虚拟物体的处理。 Virtuose 6D RV是当今市场上唯一将高工作效率与高工作量相结合在一起的产品。6D RV特别适合于缩放与操纵等应用&…

易点易动库存管理系统革新企业库存管理,降本增效

随着全球经济的快速发展和市场竞争的加剧&#xff0c;企业对库存管理的需求变得越来越迫切。传统的手工操作和繁琐的库存管理方式已经无法满足现代企业的需求。为了解决这一问题&#xff0c;易点易动库存管理系统应运而生。 易点易动库存管理系统概述 易点易动库存管理系统是一…

越南服务器租用:企业在越南办工厂的趋势与当地(ERP/OA等)系统部署的重要性

近年来&#xff0c;越南逐渐成为全球企业布局的热门目的地之一。许多企业纷纷选择在越南设立工厂&#xff0c;以利用其低廉的劳动力成本和优越的地理位置。随着企业在越南的扩张&#xff0c;对于当地部署ERP系统或OA系统等的需求也日益增长。在这种情况下&#xff0c;租用越南服…