你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【中文文档】AN2868_STM32F10xx内部RC振荡器校准

[复制链接]
STMCU-管管 发布时间:2019-4-10 14:06
STM32F10xxx内部 RC 振荡器 (HSI)校准* [4 L- c, T8 I

" ^2 t$ N) @" Q3 K8 H& ~5 P) }前言 & n2 y$ n/ d3 R
8 g3 [* O& U6 P0 _
STM32F10xxx 微控制器提供了适合运行的内部 RC 振荡器 (典型地,有 8 MHz 的 HSI:高速内部振荡器)。在 25 ℃时, HSI 的典型精度为 ±1%。在 –40 到 105 ℃, RC 频率精度值扩大为 ±3%。因此,温度对 RC 精度有影响。 + Z! X5 F+ l5 u& R: i
: Q" D$ F; s  J3 p
为补偿应用中的温度影响,用户可使用运行时校准程序,进一步微调 STM32F10xxx HSI 振荡器的输出频率,提高 HSI 的频率精度。对通信外设来说,这可能是至关重要的。 / g- b$ b; a. d2 Z3 |# G

; i0 n4 i7 {. F; V本应用笔记给出了两个校准内部 RC 振荡器的方法:找到具有最小误差的频率或找到最大允许的频率误差。两者都通过提供精确的参考源,如 RTC/64 信号或主动信号实现。
. ~7 }+ J) W% Q; r- M* ]  ~# E3 V
这两个方法都基于相同的原理:计算 RC 频率 vs. 参考频率,计算 HSI 频率误差,设置RCC_CR 寄存器中的 HSITRIM 位。% z8 x. j- z/ h5 z8 O6 H. {

$ C& S/ e2 d5 C% z7 ~# K1 STM32F10xxx 的内部时钟:HSI 时钟
+ h' ^0 p3 ^3 `# e5 f
" _( D* A0 g$ rHSI 时钟信号由内部 8 MHz RC 振荡器生成,可直接用作系统时钟,或者除以 2 用作 PLL 输入。 HSI RC 振荡器的优点是成本较低 (无需使用外部组件)。它还比 HSE 晶振具有更快的启动时间。但即使校准后,频率也不如外部晶振或陶瓷谐振器的频率精度高。 HSI 信号还可作为备份时钟源 (辅助时钟)使用,以防 HSE 晶振发生故障。
0 f9 u4 }9 c$ _1 t% _8 a) g2 S3 X8 y
9 P( O  n0 ]3 i' p. Y1.1 校准 3 a1 h* N2 R# s9 F

6 }' w& w. Y2 K+ h由于生产过程的不同,每个芯片的 RC 振荡器的频率都可能不同。因此,每个器件都由 ST做工厂校准,在 TA = 25 ℃时达到 1% 精度。
+ j; p. R, W3 ^! i/ F! N1 F7 V8 q
" L' f6 k' L! R9 e# o: q7 w. T# p$ h复位后,工厂校准值将加载到时钟控制寄存器 RCC_CR 的 HSICAL[7:0] 位中。 8 Y4 i4 L7 Y% m1 V9 m% G: W

7 [& L8 ~. t( d通过设置 RCC_CR 寄存器中的 HSITRIM[4:0] 位进行用户校准。可对这些 位编程,以考虑电压和温度变化对内部 HSI RC 振荡器频率的影响。默认值为 16,加上 HSICAL 值,应能将HSI 微调至 8 MHz ±1%。前后两个 HSICAL 步进之间的微调步长 (Fhsitrim)约为 40 kHz。- j) i" g  i; d/ }2 [
/ ]  n! D( C" p- i
2 RC 校准
! {3 J( M0 R) E

: c+ W% V& _. Q2.1 校准原理 . g+ Y. a9 N) S# ^+ b

! h: ^& f; ^% {. c! d校准的原理为首先测量 HSI 频率,然后计算频率误差,最后设置 RCC_CR 寄存器中的HSITRIM 位。
3 E) d. ~2 H8 p* \
( R" L1 X3 N9 g! Z, yHSI 频率并不是直接测量的,而是使用定时器对 HSI 时钟沿计数方式算出,然后与理想值 8000 000 Hz 比较。为此,必须有一个非常精确的参考频率,比如由外部 32 kHz 晶振提供的RTC/64 信号或 50 Hz/60 Hz 主频 (请参考第 2.2.2 章节)。对于 RTC 时钟源的情况,参考频率等于 512 Hz (32768 Hz/64)。
7 y2 S% V( Q  b; z8 i0 D5 Y( }
$ H6 d( S* M- l
图 1 显示了怎样使用定时器计数个数测量参考信号周期。8 _! P1 w1 b8 \$ @& I

* h; S* B5 T0 z1 Y/ D, a

9 A( r- }4 b: d  R4 ~9 t- i9 \
1.png
! d% t+ z/ X+ e5 v% G  K
在每个上升沿会发生两个中断:捕获比较 1 中断和更新事件中断。后者用于在参考信号周期对计数器溢出计数。因为在每个新周期开始时两个中断同时发生,所以会发生额外的溢出。这就是为什么我们必须对计数器溢出的数目减 1:N – 1。

! C/ {+ K1 e' r. {- o9 R1 V* W2 p& W2 u, z- R
6 A' q6 q/ o; J
...........
$ I$ s0 Q* u* u
想了解更多,请下载原文阅读

% ?( [8 Y6 i- d! C5 ]0 w- Q
收藏 1 评论1 发布时间:2019-4-10 14:06

举报

1个回答
Kevin_G 回答时间:2019-4-10 14:35:58
收藏
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版