OpenEdv-开源电子网

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

【困惑】对正点原子delay_ms的困惑

[复制链接]

8

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
173
金钱
173
注册时间
2016-8-18
在线时间
30 小时
发表于 2016-9-25 10:04:47 | 显示全部楼层 |阅读模式
5金钱
我在主函数while(1)中利用正点原子提供的delay_ms控制led2灯每隔500ms toggle一次,当我不开启定时器3和定时器3中断时,led2正常按照程序执行,但是我开启了定时器3和定时器3中断时,为了方便观测我在定时器3的计数器更新中断中使led1 toggle,结果led2不能按照500ms 翻转一次,反而跟着led1的节奏闪烁,没有深入研究过正点原子的delay_ms,不知为何?
输出.png

最佳答案

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

原来人家早就发现这个问题了,请看这个帖: http://www.openedv.com/posts/list/28620.htm
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

8

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2016-9-23
在线时间
37 小时
发表于 2016-9-25 10:04:48 | 显示全部楼层
回复

使用道具 举报

88

主题

7377

帖子

5

精华

资深版主

Rank: 8Rank: 8

积分
14980
金钱
14980
注册时间
2013-11-13
在线时间
1823 小时
发表于 2016-9-25 10:16:18 | 显示全部楼层
delay_ms()没有任何问题,仔细检查你的代码,LED1和LED2配置是否正确。
回复

使用道具 举报

8

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
173
金钱
173
注册时间
2016-8-18
在线时间
30 小时
 楼主| 发表于 2016-9-25 10:21:51 | 显示全部楼层
zuozhongkai 发表于 2016-9-25 10:16
delay_ms()没有任何问题,仔细检查你的代码,LED1和LED2配置是否正确。

led1和led2的函数验证多次,都是没有问题的,在你的提醒下,我再次读了led的配置函数,没有发现问题。
回复

使用道具 举报

58

主题

6293

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11477
金钱
11477
注册时间
2014-4-1
在线时间
1298 小时
发表于 2016-9-25 10:38:03 | 显示全部楼层

那就研究一下delay_ms到底什么内容。

回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-9-25 10:54:58 | 显示全部楼层
不要在中断里面调用delay_ms,否则会影响中断之外的delay_ms的运行!!
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

8

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
173
金钱
173
注册时间
2016-8-18
在线时间
30 小时
 楼主| 发表于 2016-9-25 17:23:41 | 显示全部楼层
正点原子 发表于 2016-9-25 10:54
不要在中断里面调用delay_ms,否则会影响中断之外的delay_ms的运行!!

原子哥,我在定时器3的中断服务函数中,没有使用delay_ms,刚才换了其他定时器试试,结果一样出现这种情况。不知道delay_ms这个会不会被定时器的中断函数干扰?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165377
金钱
165377
注册时间
2010-12-1
在线时间
2111 小时
发表于 2016-9-29 21:35:16 | 显示全部楼层
大海兄 发表于 2016-9-25 17:23
原子哥,我在定时器3的中断服务函数中,没有使用delay_ms,刚才换了其他定时器试试,结果一样出现这种情 ...

中断服务函数尽量短(运行时间)就行了。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

8

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
110
金钱
110
注册时间
2016-9-23
在线时间
37 小时
发表于 2016-9-30 10:37:11 | 显示全部楼层
我的程序中也开启了Tim3和Tim6,delay_ms()函数也好象无延时作用。不知道是不是冲突了。
回复

使用道具 举报

8

主题

36

帖子

0

精华

初级会员

Rank: 2

积分
173
金钱
173
注册时间
2016-8-18
在线时间
30 小时
 楼主| 发表于 2016-10-4 10:52:24 | 显示全部楼层
我在大量的操作中找到解决方法了,对于使用正点原子的delay_ms(),同时使用定时器更新中断的问题。我再描述一下,当我设置每200ms进入一次中断服务函数,在中断服务函数中我将led2翻转,在主函数中,我调用正点原子的delay_ms,每1000ms翻转一次led1。
实验现象是:两个led同时以200ms为时间间隔翻转。delay_ms无效了
我发现,只要delay_ms中延时只要小于定时器中断设定的时间,延时函数就能正常工作,所以我写了一段程序,将大的延时时间分割成每一份小的,这样就能解决问题,但是至于为什么呢?我不想深究。

主函数

主函数
搜狗截图16年10月03日2144_2.png

解决方法

解决方法
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-28 21:33

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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