OpenEdv-开源电子网

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

MDK显示运行时间不对

[复制链接]

52

主题

334

帖子

0

精华

高级会员

Rank: 4

积分
560
金钱
560
注册时间
2016-4-12
在线时间
230 小时
发表于 2019-3-18 15:23:57 | 显示全部楼层 |阅读模式
10金钱
如题,我定时器定时500ms,在线仿真,运行后第一次时间是对的,然后再运行一次,时间就不对了,但是实际运行LED间隔确实是500ms,请问为什么呢?

第一次运行.jpg

第二次运行

第二次运行
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

109

主题

5564

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10572
金钱
10572
注册时间
2017-2-18
在线时间
1914 小时
发表于 2019-3-18 21:46:09 | 显示全部楼层
你MDK是怎样设置的?(debug->settings->Trace)
回复

使用道具 举报

52

主题

334

帖子

0

精华

高级会员

Rank: 4

积分
560
金钱
560
注册时间
2016-4-12
在线时间
230 小时
 楼主| 发表于 2019-3-19 08:08:20 | 显示全部楼层
peng1554 发表于 2019-3-18 21:46
你MDK是怎样设置的?(debug->settings->Trace)

我设置的是71MHZ,也是这个结果
回复

使用道具 举报

3

主题

49

帖子

0

精华

初级会员

Rank: 2

积分
137
金钱
137
注册时间
2018-11-7
在线时间
40 小时
发表于 2019-3-19 10:47:51 | 显示全部楼层
也许是定时器时间再加上相关代码执行的时间造成的误差吧,您的时间要求确实需要那么精确吗?
回复

使用道具 举报

52

主题

334

帖子

0

精华

高级会员

Rank: 4

积分
560
金钱
560
注册时间
2016-4-12
在线时间
230 小时
 楼主| 发表于 2019-3-19 11:33:34 | 显示全部楼层
hujj 发表于 2019-3-19 10:47
也许是定时器时间再加上相关代码执行的时间造成的误差吧,您的时间要求确实需要那么精确吗?

这是我同事问我的一个问题,我也不知道什么原因造成的,所以我也来求助了,至于误差,肯定不会这么大吧,并且这个sec不应该是程序运行时间的叠加吗,比如我定时器设置500ms,我断点就打在中断中,第一次500ms进入中断,第二次这个sec就不对了,正常的不应该是第二次1s吗?
回复

使用道具 举报

109

主题

5564

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10572
金钱
10572
注册时间
2017-2-18
在线时间
1914 小时
发表于 2019-3-19 12:58:45 | 显示全部楼层
wangmingwei093 发表于 2019-3-19 11:33
这是我同事问我的一个问题,我也不知道什么原因造成的,所以我也来求助了,至于误差,肯定不会这么大吧, ...

看打的断点。这么打断点一直显示0.5s左右。0.5s进入更新中断
打断点.JPG
回复

使用道具 举报

3

主题

49

帖子

0

精华

初级会员

Rank: 2

积分
137
金钱
137
注册时间
2018-11-7
在线时间
40 小时
发表于 2019-3-19 13:06:39 | 显示全部楼层
wangmingwei093 发表于 2019-3-19 11:33
这是我同事问我的一个问题,我也不知道什么原因造成的,所以我也来求助了,至于误差,肯定不会这么大吧, ...

我理解定时器中断是定时发生的,两次中断之间的时间应该是一致的。至于您的Sec变量没有累加那是另外一回事。
您的两次运行时间差为0.50009054-0.50008887=0.00000167(秒),也就是说相差1.67微秒,这个原因我也说不清楚,猜想可能是的执行指令数不一样吧。
回复

使用道具 举报

52

主题

334

帖子

0

精华

高级会员

Rank: 4

积分
560
金钱
560
注册时间
2016-4-12
在线时间
230 小时
 楼主| 发表于 2019-3-19 13:42:01 | 显示全部楼层
peng1554 发表于 2019-3-19 12:58
看打的断点。这么打断点一直显示0.5s左右。0.5s进入更新中断

我的断点打在LED1 = !LED1这里,没有您说的那两个地方
回复

使用道具 举报

52

主题

334

帖子

0

精华

高级会员

Rank: 4

积分
560
金钱
560
注册时间
2016-4-12
在线时间
230 小时
 楼主| 发表于 2019-3-19 13:43:27 | 显示全部楼层
hujj 发表于 2019-3-19 13:06
我理解定时器中断是定时发生的,两次中断之间的时间应该是一致的。至于您的Sec变量没有累加那是另外一回 ...

您的意思是我的断点没有累加?但是我多点两次,sec时间也会累加,但是累加的都不对,我感觉是MDK哪里没设置对,挺奇怪的,我拿原子哥的mini例程试,也是这样的,再或者说我的MDK本身就有问题
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-24 03:07

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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