OpenEdv-开源电子网

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

stm32频繁复位,导致rtc定时误差问题

[复制链接]

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
发表于 2018-11-29 21:52:47 | 显示全部楼层 |阅读模式
20金钱
如题:  单片机:stm32l071  使用LSE作为内部rtc时钟源,系统每天工作一次,随后进入待机模式,在待机模式下需要频繁唤醒

问题:定时一天的情况下,实测由于频繁唤醒,会造成rtc走的时间比实际时间慢

问:

(1)理论上来说,在配置LSE作为RTC时钟源的情况下,只要不掉电,RTC一直在跑,复位为何会对rtc时间有影响?

(2)目前猜测的原因,一个是每次唤醒初始化rtc造成影响,如是该原因,可否复位后不初始化rtc?

(3)另一个可能原因是复位后需要重新配置LSE时钟,造成rtc误差,如是该原因,如何解决?

恳请高手帮忙指点一二,感谢!!!


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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2018-11-30 01:47:45 | 显示全部楼层
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-11-30 10:36:29 | 显示全部楼层
自己顶下~
回复

使用道具 举报

1

主题

32

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
276
金钱
276
注册时间
2017-10-21
在线时间
23 小时
发表于 2018-11-30 12:00:44 | 显示全部楼层
rtc本来精度就不高 可以用外部时钟芯片试试
回复

使用道具 举报

3

主题

401

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1769
金钱
1769
注册时间
2015-6-11
在线时间
313 小时
发表于 2018-11-30 15:08:33 | 显示全部楼层
ST的RTC使用内部LSI的精度不高,但你这使用的是外部LSE,精度基本上由外部晶振决定,
1.你可以用示波器量下晶振引脚的频率是否精确的32.768Khz,先计算出这个偏差。
2.进入低功耗待机、停止时并不会产生复位(除非你开启了相应的配置),唤醒时从睡眠时启动,理论上也没影响,想确定是否这个问题也很简单,你不进入低功耗模式,让设备带电(不进入低功耗)跑一天,看RTC是否和预估的一样就确定了。
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-11-30 20:52:08 | 显示全部楼层
zc123 发表于 2018-11-30 15:08
ST的RTC使用内部LSI的精度不高,但你这使用的是外部LSE,精度基本上由外部晶振决定,
1.你可以用示波器量 ...

感谢回复!!是这样:
(1)目前身边的仪器条件不满足测晶振的准确振荡频率,但根据晶振手册的描述,理论一天的误差在秒级
(2)您建议的第二点我这里测试过,在不频繁进睡眠的情况下,一天的误差在2s左右。而且我在工作状态下测试过,rtc定时一小时误差很小,一旦加上频繁的待机和唤醒,误差就大了。一天的误差在一分钟左右
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-11-30 20:55:10 | 显示全部楼层
LIFU 发表于 2018-11-30 12:00
rtc本来精度就不高 可以用外部时钟芯片试试

感谢回复!目前项目硬件已经确定,暂时无法采用外部芯片。另外就以内部RTC来说,理论一天的误差也不应像现在这么大。不过还是谢谢您的回复!
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-12-1 13:39:07 | 显示全部楼层
自己顶
回复

使用道具 举报

6

主题

108

帖子

1

精华

高级会员

Rank: 4

积分
716
金钱
716
注册时间
2017-4-25
在线时间
203 小时
发表于 2018-12-1 14:18:35 | 显示全部楼层
每天工作一次?那为什么还要频繁唤醒。。
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-12-1 16:55:57 | 显示全部楼层
biglu 发表于 2018-12-1 14:18
每天工作一次?那为什么还要频繁唤醒。。

采用了内部独立看门狗,睡眠状态下每隔一段时间唤醒喂狗
回复

使用道具 举报

6

主题

108

帖子

1

精华

高级会员

Rank: 4

积分
716
金钱
716
注册时间
2017-4-25
在线时间
203 小时
发表于 2018-12-1 22:38:10 | 显示全部楼层
supergao 发表于 2018-12-1 16:55
采用了内部独立看门狗,睡眠状态下每隔一段时间唤醒喂狗

一天工作工作一次,感觉闹钟唤醒够了啊,用的时间这么少发生错误概率也低啊,要稳定还是硬件看门狗
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-12-2 15:33:47 | 显示全部楼层
biglu 发表于 2018-12-1 22:38
一天工作工作一次,感觉闹钟唤醒够了啊,用的时间这么少发生错误概率也低啊,要稳定还是硬件看门狗

感谢回复,感谢~
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-12-2 20:59:07 | 显示全部楼层
自己顶一下~
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-12-5 00:25:28 来自手机 | 显示全部楼层
自己顶一下…
回复

使用道具 举报

12

主题

37

帖子

0

精华

初级会员

Rank: 2

积分
83
金钱
83
注册时间
2012-9-11
在线时间
30 小时
 楼主| 发表于 2018-12-5 10:17:49 | 显示全部楼层
自己顶一下~
回复

使用道具 举报

3

主题

401

帖子

1

精华

金牌会员

Rank: 6Rank: 6

积分
1769
金钱
1769
注册时间
2015-6-11
在线时间
313 小时
发表于 2018-12-8 10:56:28 | 显示全部楼层
本帖最后由 zc123 于 2018-12-8 10:59 编辑

你这个问题我怀疑是唤醒定时时间和看门狗喂狗时间比较接近,喂狗不及时导致复位,然后软件又进行了RTC的重新初始化,你可以保持现在的代码不变(就是正常唤醒-休眠轮询),但屏蔽掉看门狗相关的代码,在测试看看。还有你既然做低功耗产品,用什么看门狗啊,不要想着面面俱到,看门狗和低功耗产品的需求是冲突的。
回复

使用道具 举报

233

主题

961

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1814
金钱
1814
注册时间
2011-10-9
在线时间
230 小时
发表于 2018-12-8 13:27:07 | 显示全部楼层
最笨的办法   测出 误差秒数 与 唤醒次数的关系   然后每次唤醒补偿下就拉倒了   。
回复

使用道具 举报

0

主题

2

帖子

0

精华

新手入门

积分
7
金钱
7
注册时间
2019-6-11
在线时间
1 小时
发表于 2019-6-11 16:41:58 | 显示全部楼层
您最后这个问题怎么解决的呢?
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-17 09:00

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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