找回密码
 注册
关于网站域名变更的通知
查看: 383|回复: 3
打印 上一主题 下一主题

如何理解AT32的RTC以及ERTC的时钟分频

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-10-8 11:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
AT32 系列的单片机里面有两种RTC,一种是RTC另外一种是ERTC,两种RTC的分频值配置略有不同
0 v; }9 o1 u( x* h$ i- ZRTC:  g% F" D) Y2 |7 Q" K
; J1 k" ]" U. w! N
上图是从官方参考手册上截取的RTC内部框图,从图中我们可以看到,RTCCLK经过20位分频器RTC_DIV分频后得到日历的1Hz时钟,所以我们只需要配置RTC_DIV就行了,分频公式为RTC_CLK/(RTC_DIV+1). L8 b# y0 x1 h) i1 Y- z% k
例如当外部晶振为32768Hz,那么配置RTC_DIV=32767就能得到1Hz时钟,32768/(32767+1) = 1Hz
/ ^/ f2 v3 m( h程序示例:
$ C( K$ L" S7 n1 {3 Q( BRTC_SetDIV(32767);( t* z+ v5 K% {; y1 `
, k1 d2 j2 d1 [7 |
ERTC:
7 I. Z* |# }# x
上图是从官方参考手册上截取的ERTC内部框图,从图中我们可以看到,ERTCCLK先经过7位分频器,再经过15位分频器,得到后得到日历的1Hz时钟,所以我们只需要配置7位分频器,以及15位分频器,分频公式为ERTC_CLK/((7位分频器+1)(15位分频器+1))+ b. C6 O- ~! m7 V9 w; m
例如当外部晶振为32768Hz,那么配置7位分频器=127,15位分频器=255,就能得到1Hz时钟,32768/(127+1)(255+1) = 1Hz
& H3 D; H2 {: v7 x程序示例:  q2 d; E6 i% i
  ERTC_InitStructure.ERTC_AsynchPrediv = 127;" g; `" t1 T0 {2 u- L
  ERTC_InitStructure.ERTC_SynchPrediv =  255;
1 W/ ]$ F3 O# X# `9 S; f/ x  ERTC_InitStructure.ERTC_HouRFormat = ERTC_HourFormat_24;
- O* u$ k/ z6 F$ v: t0 y3 ^  ERTC_Init(&ERTC_InitStructure);. G. A# ?$ p4 d: J/ S3 i
/ N* ?0 c$ X' I3 _" j  e8 a8 Y, m
* W+ a' x9 [0 Q1 M
% N1 F# o3 w6 R0 h( N3 F1 u
8 z/ ]- t( f. g- I: V

该用户从未签到

2#
发表于 2021-10-8 13:06 | 只看该作者
学习了   感谢分享

该用户从未签到

3#
发表于 2021-10-8 14:14 | 只看该作者
ERTCCLK先经过7位分频器,再经过15位分频器,得到后得到日历的1Hz时钟

该用户从未签到

4#
发表于 2021-10-8 14:20 | 只看该作者
写的不错  支持
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-10-12 21:41 , Processed in 0.140625 second(s), 23 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

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