OpenEdv-开源电子网

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

定时器4ms一次溢出中断在中断里面添加串口打印函数会影响串口接收

[复制链接]

5

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2017-10-6
在线时间
39 小时
发表于 2018-5-26 18:07:03 | 显示全部楼层 |阅读模式
1金钱
如题
QQ图片20180526180557.png

最佳答案

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

波特率9600:9600bit/s(一个起始位一个停止位) 9.6bit/ms 你的printf(“zzzzzz\r\n”);共8byte,每个byte发送时带一个起始位一个停止位共10bit,也就是需要发送8byte*10bit=80bit,需要耗时80bit/9.6bit/ms=8.3333ms。就这还不算你调用printf的时间,这个函数很耗时间的。你的定时器4ms一次中断太快了。 波特率115200:115200bit/s(一个起始位一个停止位) 115.2bit/ms 你的printf(“zzzzzz\r\n ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

26

主题

1533

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
6369
金钱
6369
注册时间
2015-8-25
在线时间
1004 小时
发表于 2018-5-26 18:07:04 | 显示全部楼层
波特率9600:9600bit/s(一个起始位一个停止位)         9.6bit/ms      你的printf(“zzzzzz\r\n”);共8byte,每个byte发送时带一个起始位一个停止位共10bit,也就是需要发送8byte*10bit=80bit,需要耗时80bit/9.6bit/ms=8.3333ms。就这还不算你调用printf的时间,这个函数很耗时间的。你的定时器4ms一次中断太快了。
波特率115200:115200bit/s(一个起始位一个停止位)         115.2bit/ms      你的printf(“zzzzzz\r\n”);共8byte,每个byte发送时带一个起始位一个停止位共10bit,也就是需要发送8byte*10bit=80bit,需要耗时80bit/115.2bit/ms=0.694ms。这个波特率不合适还是“printf的执行时间,这个函数很耗时间的”
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手上路

积分
21
金钱
21
注册时间
2018-5-21
在线时间
1 小时
发表于 2018-5-26 19:43:23 | 显示全部楼层
可以试试把波特率调高一点
或者进入临界区试试
回复

使用道具 举报

3

主题

1155

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
7462
金钱
7462
注册时间
2015-1-15
在线时间
1367 小时
发表于 2018-5-26 19:58:47 来自手机 | 显示全部楼层
中断函数没就别用这么耗时间的函数,
回复

使用道具 举报

5

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2017-10-6
在线时间
39 小时
 楼主| 发表于 2024-6-22 15:59:00 | 显示全部楼层
szczyb1314 发表于 2018-5-26 18:07
波特率9600:9600bit/s(一个起始位一个停止位)         9.6bit/ms      你的printf(“zzzzzz\r\n”);共 ...

感谢解答
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-22 11:32

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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