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

【中文文档】AN3300_如何校准STM32L1xx内部RC振荡器

[复制链接]
STMCU-管管 发布时间:2019-4-3 09:46
如何校准 STM32L1xx 内部 RC 振荡器
4 F$ E9 B% U: q! Z' G. [
2 v! J4 G4 r! V/ z) o3 E2 a前言 # w8 L# h4 g2 H6 D. [4 x3 u0 `, A

9 \( E; ]* q8 l1 d1 ~) eSTM32L1xx 微控制器有两个内部 RC 振荡器可做为系统时钟源。它们是 HSI(高速内部)和MSI(多速内部)振荡器。HSI 振荡器的典型频率为 16 MHz。MSI 振荡器为低速、低功耗时钟源。
7 E/ B- c! u( m. ?$ G# q& x7 J, j& g' _4 u  }- d
工作温度对 RC 振荡器的精度有影响。在 25 ℃时,HSI 和 MSI 振荡器的典型精度为 ±1%,但在 -40 到 105 ℃温度范围,精度会降低。 / `$ j4 ~$ A: U
- j8 F# A* Z+ T& J3 v- e
为补偿温度对内部 RC 振荡器精度的影响,STM32L1xx 微控制器的内置一些功能可帮您校准HSI 和 MSI 振荡器及测量 MSI 和 LSI (低速内部)振荡器频率。 - z+ s) r$ s1 U2 |& \% M
5 j( _1 s' k6 {3 N1 X
本应用笔记侧重如何校准内部 RC 振荡器:HSI 和 MSI。它展示了两个方法:第一个方法基于寻找具有最低误差的频率,第二个方法是寻找具有最大允许误差的频率。两个方法都通过提供精确参考信号的方式实现。
8 _* Y' N  Y  A1 e" h/ ?) D

2 G' Q* W& U( }; v  H4 J/ JMSI 和 LSI 振荡器的测量都是通过将振荡器连至定时器输入捕获执行。
+ l" s' W0 x$ @! L! X1 S9 M8 I

" |9 D& m5 ?" ~9 u2 ?& o( e 注 : 1 在本文中, STM32L1xx 指超低功耗大容量、中容量增强型、中容量器件。2 超低功耗中容量器件为 STM32L151xx 和 STM32L152xx 微控制器,其闪存密度范围为 64至 128K 字节。3 超低功耗中容量增强型器件为 STM32L151xx、 STM32L152xx 和 STM32L162xx 微控制器,其闪存密度为 256 K 字节。4 超低功耗大容量器件为 STM32L151xx、STM32L152xx 和 STM32L162xx 微控制器,其闪存密度为 384 K 字节。
! D; a: B( `- ]/ y
) N- t6 M1 D6 U! x% _1 STM32L1xx 系统时钟 ! n( [0 \4 G/ x* z! t2 L9 X
0 d1 H9 h$ V2 D1 u, U: O
STM32L1xx 微控制器系列有多个时钟源可用于驱动系统时钟: : \+ p6 x5 o8 Z( P8 k& t. ~- w
● 16 MHz 高速内部 (HSI) RC 振荡器时钟
: O' }) v+ J, m$ f- h● 1 至 24 MHz 高速外部 (HSE)振荡器时钟
0 Y: ]% d* R9 A. _. Q5 Q● 65.5 kHz 至 4.2 MHz 多速内部 (MSI) RC 振荡器时钟
4 m3 T' {! a& }; i2 ?1 l1 q. U● 2 至 24 MHz 锁相环 (PLL),由 HSI 或 HSE 振荡器提供时钟 2 H3 O% N, N3 ?. L
# E8 y& J' t4 C
高速内部 (HSI) RC 振荡器一般频率为 16 MHz,耗电 100 µA。
7 X5 v- a* P+ _# `$ X! n, I0 M9 }1 `! l- S  c' j
多速内部(MSI)RC 振荡器提供了七个频率范围:65.5 kHz、131 kHz、262 kHz、524 kHz、1.05 MHz、 2.1 MHz (默认值)和 4.2 MHz。它的设计为工作电流与频率成正比 (请参考产品手册以获得 MSI 耗电与所选频率范围之间关系的更详细信息),因此当 CPU 在低频运行时,内部振荡器耗电可最小化。在从复位重启、从停止唤醒、待机低功耗模式后, MSI 时钟被用作系统时钟。
% V/ [7 M) l4 _" {& v) A7 |+ R1 a4 E2 T& [8 H( a( r8 r( v' T
内部 RC 振荡器 (HSI 和 MSI)提供了低成本时钟源 (不需外部元件),这是其优点。它还具有比外部振荡器更快的启动时间和更低的功耗。可校准 HSI 和 MSI 振荡器以提高其精度。但即使校准后,内部RC振荡器频率也不如外部晶振或陶瓷谐振器的频率精度(几十ppm)高。
- F" m( W8 c4 e$ l* \' v! l' I, z: D; T: p1 o2 d! ]* ~. [+ @: _
注 : 若外部振荡器发生故障,内部 RC 振荡器 (HSI 和 MSI)还可作为备份时钟源 (辅助时钟)使用。7 S8 W% w5 w8 U. x9 ?" o( }; u  \
, X8 ?# B2 c/ b$ y! b: f! b
1.png

7 r' U. `- g! k" J+ @. d" |# ]- [4 n0 J" V
STM32L1x 器件还有两个次级时钟源 (不能用作系统时钟源):
5 D% u' v+ |" H# A7 M) w" N6 r
● 37 kHz 低速内部 (LSI) RC,设计为驱动独立看门狗,也可驱动实时时钟 (RTC)。该 LSI 振荡器无法校准,但可对其测量以评估 (由温度和电压变化引起的)频率偏差
* A: c- H! p3 M5 T' n/ E
● 32.768 kHz 低速外部晶振 (LSE 晶振),用于驱动实时时钟 (RTC)

% E7 K6 Z1 O& {1 q
2 内部 RC 振荡器校准

) u3 \/ G  t* Q" {5 ~% B/ ]& a
由于生产过程的不同,每个芯片的内部 RC 振荡器的频率都可能不同。因此,MSI 和 HSI RC振荡器由 ST 工厂校准,以获得 TA = 25 ℃时 1% 的精度。复位后,工厂校准值自动加载到内部校准位中。

, l+ p% w& P: P
可微调内部 RC 振荡器的频率,以在更宽的温度和供电范围内达到更好的精度。这就是微调位的作用。

3 j7 L4 Q4 o) s4 P8 w
对于 HSI 振荡器,复位后校准值加载于 HSICAL[7:0] 位中。有五个微调位 HSITRIM[4:0] 用于微调。默认微调值为 16。增加 / 降低此微调值会增加 / 降低 HSI 频率。 HSI 振荡器微调步长为 0.5% (在 80 kHz 周围)。
7 t/ L. @  v, M; T; x! f1 S
● 将微调值写为 17 至 31 会增加 HSI 频率。

* ]/ J) Y9 p4 G" K2 j; w
● 将微调值写为 0 至 15 会降低 HSI 频率。

# ^! {5 E: n6 Q! G! }
● 将微调值写为 16, HSI 频率会保持为默认值。
1 z1 }, t. f7 N& K
下图显示了随校准值变化的 HSI 振荡器行为。HSI 振荡器频率随校准值增加(校准值 = 默认的 HSICAL[7:0] + HSITRIM[4:0]),除了在模 16 处。在这些校准值处,负步进会达到正步进的三倍。
3 n7 x7 P/ D2 k" C. e, {* M
1.png

! {6 o$ e, U, U% j: E
● 对于 MSI 振荡器,复位后校准值加载于 MSICAL[7:0] 位中。使用了八个微调位MSITRIM[7:0],因此有更宽的调整范围。校准基于将默认的 MSICAL[7:0] 位 (复位值)加上 MSITRIM[7:0] 位。结果储存于 MSICAL[7:0] 中:

* f% e3 q+ H) ?
MSICAL[7:0] = 默认的 MSICAL[7:0] + MSITRIM[7:0]

- G  h4 |9 i/ |1 W" I: [! r
示例:假设默认的 MSI 校准值 MSICAL[7:0] 为 0x80。

: w1 p3 w3 F" g. S: H; R6 _) Z
1. 将 0x01 到 0x7F 之间的值写入 MSITRIM[7:0] 会导致校准值 MSICAL[7:0] 的范围为:MSICAL[7:0] = 0x80 + 0x01 = 0x81及 MSICAL[7:0] = 0x80 + 0x7F = 0xFF这些结果大于 0x80 (默认的 MSI[7:0] 值),因此 MSI 频率增加 1 步 (0x81 -0x80)至 127 步 (0xFF - 0x80)。
- b2 \/ Y5 c; |, e
2. 将 0x81 到 0xFF 之间的值写入 MSITRIM[7:0] 会导致校准值 MSICAL[7:0] 的范围为:MSICAL[7:0] = 0x80 + 0x81 = 0x01及 MSICAL[7:0] = 0x80 + 0xFF = 0X7F这些结果小于 0x80 (默认的 MSI[7:0] 值),因此 MSI 频率降低 1 步 (0x01)至127 步 (0x7F)。

2 y2 d' \  A$ r6 G( _
3. 在 MSITRIM[7:0] 中写入默认校准值 (0x80)会导致校准值 MSICAL[7:0] 等于MSICAL[7:0] = 0x80 + 0x80 = 0x00,因此 MSI 频率会降低 128 步 (最低频率)。
# K: I/ |7 W6 ~
下面的图 3 显示了在范围 6 (4194304 Hz)处 MSI 行为随 MSICAL[7:0] 的变化。
5 @- _6 I) R" R( O& }; h) m  b# p, q
1.png

! X0 x& k. }/ ^/ W1 H( ^
请注意当两个 MSB 位从 “00” 到 “01”、从 “01” 到 “10”、从 “10” 到 “11” 时的负步进。对六个LSB 的更改会导致每步大约 0.5% 的微调。
% u) ^1 n" O( a- r
2.1 校准原理

! @& j( w6 A) Q- u/ `
校准原理包括:
0 R* r, M( d7 C1 u) \7 K
1. 将 (需要校准的)内部 RC 振荡器设置为系统时钟,
  T3 Z3 k  F. [- ?
2. 测量每个微调值的内部 RC 振荡器 (HSI 或 MSI)频率,
6 A. d. _! a: ?; j  ]
3. 计算每个微调值的频率误差,

7 c5 X: E5 C$ ^, q
4. 最后,将微调位设置为最优值 (对应于最低频率误差)。

4 O3 s; e: c' m+ L& C+ `0 y" M9 H
内部振荡器频率并非直接测量,而是使用定时器计算时钟脉冲个数,与典型值比较。为此,必须有一个非常精确的参考频率,比如由外部 32.768 kHz 晶振或 50 Hz/60 Hz 电源频率(请参考第 2.2.2 章节 : 其它源用作参考频率的情况)。
, O. F8 s2 Y' }/ y, E
下图显示了怎样使用定时器计数个数测量参考信号周期。
4 ?3 H3 }; l  J# g/ m) v  m
...........

, ^* W5 X  f4 U# E4 t' j1 v0 G# o
想了解更多,请下载原文阅读
% f4 G+ u8 Y  C+ h3 s9 L  K# |
1 收藏 2 评论2 发布时间:2019-4-3 09:46

举报

2个回答
Kevin_G 回答时间:2019-4-3 10:06:53
收藏
雨一直下_ 回答时间:2020-8-27 10:59:12
超级使用资料,正在较准时钟
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版