OpenEdv-开源电子网

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

F407芯片CAN总线收发耗时的测量

[复制链接]

2

主题

8

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-9-8
在线时间
7 小时
发表于 2016-12-15 14:26:39 | 显示全部楼层 |阅读模式
2金钱
STM32F407单片机通过CAN总线收发数据,一帧数据16字节,波特率1Mbps,8字节数据全部填充,标准ID。

我的理解是:1Mbps的速率,发送一位需要1us(理论上),16字节总共128bit,所有至少需要128us。而我测量的时间,发送一帧需要260us,时间相差一倍!

我测量的方式是:在数据写入寄存器TTR、TDLR、TDHR后申请发送请求的时候开始测量,在中断标志位检测到RQCP、TXOK被置位(即检测到发送成功标志)的时候结束测量。这一段时间我理解为CAN控制器完成了一帧数据的发送。

现在不确定是否我的理解有问题,还有相差一倍的时间有点离谱。求各种指点!

最佳答案

查看完整内容[请看2#楼]

你的理解和测试方法应当没问题。 除了前面“天空淡云”说的原因, 还有个通信机制问题: CAN是多主机的方式,它能自动侦测总线是否空闲,避开忙状态, 如果总线被占用,自然会延后。 你要确保总线是空闲的。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

58

主题

6294

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11555
金钱
11555
注册时间
2014-4-1
在线时间
1317 小时
发表于 2016-12-15 14:26:40 | 显示全部楼层
本帖最后由 xuande 于 2016-12-15 19:44 编辑


你的理解和测试方法应当没问题。

除了前面“天空淡云”说的原因,
还有个通信机制问题:
CAN是多主机的方式,它能自动侦测总线是否空闲,避开忙状态,
如果总线被占用,自然会延后。
你要确保总线是空闲的。

回复

使用道具 举报

2

主题

8

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-9-8
在线时间
7 小时
 楼主| 发表于 2016-12-15 16:50:29 | 显示全部楼层
难道是我提问的方式不对吗?好像没有人看啊?!
回复

使用道具 举报

26

主题

105

帖子

0

精华

高级会员

Rank: 4

积分
894
金钱
894
注册时间
2015-10-25
在线时间
117 小时
发表于 2016-12-15 18:41:15 | 显示全部楼层
我最近也在看STM32F4的CAN,一帧数据不是包含7个段吗,你的8字节只是数据段,其他段的时间呢
回复

使用道具 举报

2

主题

8

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-9-8
在线时间
7 小时
 楼主| 发表于 2016-12-16 18:06:45 | 显示全部楼层
天空淡云 发表于 2016-12-15 18:41
我最近也在看STM32F4的CAN,一帧数据不是包含7个段吗,你的8字节只是数据段,其他段的时间呢

谢谢。我没有表述清楚,我说的16字节指的是一帧数据的长度,按照定义的结构体把数据段加上其他的rtr、ide、id等等(实际应该不到16字节)。8字节数据位是64bits,加上其他的数据位,我按照128bits的宽度来计算的。
回复

使用道具 举报

2

主题

8

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-9-8
在线时间
7 小时
 楼主| 发表于 2016-12-16 18:20:13 | 显示全部楼层
xuande 发表于 2016-12-15 19:42
你的理解和测试方法应当没问题。

除了前面“天空淡云”说的原因,

Thank you。

1、我测量的时候是某个节点只发一次,然后测量的耗时,所以应该不会是忙状态。
2、正常工作时,目前CAN网络有四个节点,A分别向BCD三个节点以833Hz的频率请求数据,BCD收到请求后立即返回数据,全部是标准帧。
3、目前考虑是不是CAN总线机制的问题,或者CAN收发器本身会有一定耗时操作(脑洞有点大)
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-12-17 18:17:02 | 显示全部楼层
4wards 发表于 2016-12-16 18:20
Thank you。

1、我测量的时候是某个节点只发一次,然后测量的耗时,所以应该不会是忙状态。

试下点对点(不要有其他节点),大量数据发送,然后求平均时间。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

2

主题

8

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-9-8
在线时间
7 小时
 楼主| 发表于 2016-12-19 09:45:45 | 显示全部楼层
正点原子 发表于 2016-12-17 18:17
试下点对点(不要有其他节点),大量数据发送,然后求平均时间。

Thank you.

今天试一下,两天没上网了。
回复

使用道具 举报

2

主题

8

帖子

0

精华

新手上路

积分
28
金钱
28
注册时间
2016-9-8
在线时间
7 小时
 楼主| 发表于 2016-12-19 10:10:48 | 显示全部楼层
4wards 发表于 2016-12-19 09:45
Thank you.

今天试一下,两天没上网了。

估计知道原因了:我是单片机的定时器来测的,最高分辨率是1us!然而它发送一个bit可能仅需要1.001us,然而多出的0.001us也会被计算为1us!问题可能就出在这里。还是用示波器测吧!(主要是手上没有示波器,才想的这个土办法!)
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-21 07:16

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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