OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5516|回复: 7

stm32 can通信延迟时间过长

[复制链接]

6

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-4-20
在线时间
11 小时
发表于 2023-3-1 11:27:29 | 显示全部楼层 |阅读模式
5金钱
在做CAN通信试验过程中 有一个主机,3个从机, 主机每3秒钟向纵向广播 一个同步数据包 ID==0, 3个从机接收到该数据包后,都各自响应主机,3个从机发出的响应包ID分别是1、2、3, 问题是:主机接收到三个从机的响应包耗时2秒中,未免太久了,。每个数据包长度3个字节,一包数据68个位,4个设备发送数据量才272个位,通信波特率设置的是1Mbs, 272个位耗时也不过0.272ms 还不到1ms 。我判断延迟,是不是芯片在判忙总线的时候会有延迟?

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-4-20
在线时间
11 小时
 楼主| 发表于 2023-3-1 11:28:25 | 显示全部楼层
主机每3秒钟向总线广播 一个同步数据包 ID==0,
回复

使用道具 举报

12

主题

3344

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8462
金钱
8462
注册时间
2020-5-11
在线时间
3904 小时
发表于 2023-3-1 11:42:48 | 显示全部楼层
如果多个从机同时发送,估计会有冲突、会有仲裁、会有重发。
建议从机根据地址错开数据包,比如0号立即发送,1号延迟10ms发送,2号延迟20ms发送。
专治疑难杂症
回复

使用道具 举报

6

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-4-20
在线时间
11 小时
 楼主| 发表于 2023-3-1 13:00:38 | 显示全部楼层
LcwSwust 发表于 2023-3-1 11:42
如果多个从机同时发送,估计会有冲突、会有仲裁、会有重发。
建议从机根据地址错开数据包,比如0号立即发 ...

那肯定会有仲裁,所以3个从机发送的响应包的ID都是不同的,分别是1、2、3。而且接收到同步包后,我也加延时才发送响应包,但是没有延时这么长时间,1号从机立即响应,2号延时4ms ,3号延时6ms
现象就是:芯片对总线进行判忙后可能延时很久才重新发送。
回复

使用道具 举报

12

主题

3344

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8462
金钱
8462
注册时间
2020-5-11
在线时间
3904 小时
发表于 2023-3-1 13:29:31 | 显示全部楼层
chunlele 发表于 2023-3-1 13:00
那肯定会有仲裁,所以3个从机发送的响应包的ID都是不同的,分别是1、2、3。而且接收到同步包后,我也加延 ...

用示波器监测一下CANH、CANL波形,一是看波形方不方,二是看那2秒钟里是否一直有波形。
另外再试一下只接入一个从机。
专治疑难杂症
回复

使用道具 举报

6

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-4-20
在线时间
11 小时
 楼主| 发表于 2023-3-2 08:14:41 | 显示全部楼层
LcwSwust 发表于 2023-3-1 13:29
用示波器监测一下CANH、CANL波形,一是看波形方不方,二是看那2秒钟里是否一直有波形。
另外再试一下只 ...

感谢大哥跟帖,问题已经找到了,是  主机那边处理延迟了。分享下调试过程:在从机那边启用一个定时器,接收到数据后记录以下定时器的数值为time1,发送前记录定时器值time2,发送完成后再记录定时器值time3,这样就知道从接收到数据到处理数据的延迟detime1=time2-time1,发从用时detime2=time3-time2  时间都不超过0.1ms ,同样的方法找到了主机的产生延迟的地方。
回复

使用道具 举报

6

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
77
金钱
77
注册时间
2017-4-20
在线时间
11 小时
 楼主| 发表于 2023-3-2 08:15:50 | 显示全部楼层
LcwSwust 发表于 2023-3-1 13:29
用示波器监测一下CANH、CANL波形,一是看波形方不方,二是看那2秒钟里是否一直有波形。
另外再试一下只 ...

大哥,示波器怎么抓取这种通信的偶发出现的波形?
回复

使用道具 举报

12

主题

3344

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8462
金钱
8462
注册时间
2020-5-11
在线时间
3904 小时
发表于 2023-3-2 09:27:09 | 显示全部楼层
chunlele 发表于 2023-3-2 08:15
大哥,示波器怎么抓取这种通信的偶发出现的波形?

示波器的触发模式一般有三种:自动、普通、单次,除自动模式外,其它两种都能抓取。
自己找找设置一下试试。
专治疑难杂症
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-24 17:38

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表