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

STM32中的时钟系统

[复制链接]
STMCU小助手 发布时间:2022-12-27 18:00
STM32中的时钟系统概述5 X9 G# v- }3 h: V: s* F( x

& {4 ~0 {: D) E$ m
1dfa787f80984cc0a9a3743540fba491.png 0 l6 E1 U# s/ z4 M5 G) O
  q9 H/ c. r0 f% M: Y% l1 r
5个蓝色背景的是时钟源
1 x5 E( J  B2 ~% \* v8 j% O
  q; Q( W, m+ }/ d( F) oSYSCLK是系统时钟,最重要的时钟,可以看到其他的外设的时钟都来源于系统时钟' J! @8 @. u$ V+ h. j7 s* Q, l' B  w
7 N- h& b0 E8 O$ }" e# j
HSI RC高速内部: q. |% ^& K) O) v4 Y9 ^
约为8MHz,但不太稳定,可以作为系统时钟,灰色背景的梯形表示选择器
( F& z, |9 z0 f* F1 d" u5 w

, r) I; |- _0 `$ H" [HSE Os高速外部
, F8 A' n# I% p/ h  t4 U接晶振,例如8MHz,其可以直接作为选择器的输入,也可以分频后作为选择器输入,PLL表示锁相环,用于倍频,可以选择2-16,通过锁相环寄存器配置,产生的时钟为PLL_CLK0 c9 L5 P+ p# H. Y% g  p: q4 {
/ D- G0 V1 k/ R9 q/ C- i  L' H
CSS时钟监控系统- ]% }& l! @3 w- ~, _; {8 C! ~1 \
一旦HSE失效,则自动切换到SYSCLK=HSI, M% F) J7 j) y4 L. u" U# B9 b- t
2 L5 Q& {% M; d, D1 n# [/ W
LSE Os低速的外部时钟
' H1 @. n% ^' Q: j% K" v通过外接晶振产生,一般为32.768kHz,用于RTCCLK
, j# f' ?, I- P% \& Y- i& v7 Q4 G+ }# F
RTCCLK还可以来自于HSE的128分频
6 ?( S2 ]0 x7 D- C

) q; a6 d9 {# A7 R( p7 ULSI RC低速内部! z( p% f8 |( l' c: {" p6 g. t5 F
由内部的RC振荡器产生,约为40kHz3 A+ u, E, C7 R& Z% s8 [8 A

+ q! k. j$ f* @/ H主要是用于STM32的独立watch dog提供时钟7 C" C% O2 v4 d1 Y2 e) W1 f

& ?- i# P! ]6 M. h
: S- n4 C% n$ s/ ^7 g% |
MCO输出内部时钟引脚PA8
- p- k/ \, j/ J8 Z" q) W9 d# K3 O可以来自于系统时钟SYSCLK
- r, u" p9 M0 T, d
2 O. i- W  G% Q8 B1 J
可以来自于HSI; U* h7 U* R7 m6 X
- ^- T% X" o" Y) z5 S+ P
可以来自于HSE
2 N& R9 q, e0 K# D/ N
: }5 t! k3 z! S4 L7 H4 m
可以来自于PLLCLK的2分频
6 P, K3 N5 }8 _! H! S; t- {# ]# ^3 y& p$ Y/ }8 ^5 I2 Z6 C
USB时钟
% z6 j2 q) ?# o* z48MHz,可以来自于PLL时钟经过USB分频器,除以1或者1.54 I+ J( I# C6 W2 m  Q

% o3 v; b: \/ ~2 B72MHz和48MHz之间的倍数就是1.5
$ b3 I7 ]0 n+ \  y8 y0 C
- M- U4 D; A- l! t! x0 r) kAHB Prescaler AHB预分频器
; C) x1 h5 b0 ]% G# ~4 ~: A  nAHB预分频器的分频因子有9种选择:
% b$ y* B: ]) p) q  t! W. N
1,2,4,8,16,64,128,256,5124 O: a2 R/ m- ?$ N

  J/ B5 U/ ]4 B! m4 c8 {9 J* ]1 ?分频后产生HCLK这个时钟最高可以到72MHz
6 K% K8 H9 N! Z
1 Z' y- \5 z, f; C4 n5 l- ?
APB1 Prescale APB1预分频器; _% a, I; u- y# o5 L. X
产生PCLK1,用于挂低速外设,例如通用定时器, G3 M0 [9 {1 P3 E

2 I/ n. T# r! @: R. Y4 }APB2 Prescale APB2预分频器
' ~3 h2 O& k/ x1 T产生PCLK2,可以供对于时钟要求高的外设
; @4 W5 k5 v0 o. t) R
% H* j3 W. _& n7 E* ~' c
注意:任何一个外设使用前,必须首先使能其相应的时钟2 |, ]2 [: Z% Z% N" L% E
- Z% o' d! z" e
  _3 I& w0 ]# v3 }# M
stm32中的时钟配置RCC, B5 b# @( z  E2 _" D  j
如下图所示,为STM32工程中对于时钟的配置文件( r  G5 v/ `9 h' n3 E4 r2 n9 R
7 P& D& T& i& `# o  E9 k1 ~3 X( g
99851e60f018412a8651f4f8bf598a39.png ! N7 @/ \9 e. F. o% R

# R8 z) n: @# w- }+ I, j首先打开寄存器地址名称映射头文件
9 g9 h7 ]. _! O0 q- x. G* ~6 J

9 H  H' y, E( W' P9 d5 `这个头文件中对于大部分寄存器的映射都会在这里通过一个结构体来定义% A9 Z7 ~3 R- o) T  E

+ ?9 t" ^! b8 y7 S# F2 ?" C' ~
4671e13f8dbe4c0e8c1f459c856b6370.png
! w! L3 ]% {. J' J! A8 I4 W0 f8 ]+ g% g; ^, M" t2 @$ V# t
如下图所示,这个结构体中的成员变量映射了对应的寄存器8 ^* }6 c4 W# G; \
$ Y& s- v6 |  l, K4 b4 P6 B
78e1d7015a7848bd8b34505eba25d43a.png
# Z; T( d; c, F. v9 `: f
2 M3 O0 l/ [6 S: S2 H
对于RCC寄存器的详细描述,可以参考STM32中文参考手册
& Q: c7 _! i5 h; O
4 V- b( l, [! m- _% V4 U9 X: s
4a26bce9037041b787657de7edb60174.png
# K9 `# x8 m8 o) `
& a: G1 @1 ?1 @

- E% F' x: P5 ?1 V. DRCC时钟控制寄存器
* G2 X: N: u+ y& ]HSI,HSE,LSI,LSE,PLL这5个时钟源,使用前需要使能,使能后还不稳定,稳定后会产生稳定标志位4 B' M& D6 x" q; _, J1 m+ h
- t( p/ X- c$ T, B
30131992d96f4ed9b02432ba835e7ba4.png & q& j' Q) v3 @2 u' G. i

; V! E8 h1 c& O4 _% o
/ r1 A5 j$ f, [4 \( H3 r) H
RCC时钟配置寄存CFGR

" S" \6 s( ?0 ~配置选择器,PLL倍频系数,Scaler的分频系数0 w" _  S5 k- R! H4 Y+ B
7 {! a9 S+ R) b
32dfbfb4fe0941ce94851a80f25423a0.png
; }; ?' N8 j; B5 C3 \4 A# d0 l% t5 @: U2 j+ A2 c# X: i  V

& m( M* j* O! K7 F3 J. p2 B0 ]- e 35598cb4ab344e148de79574e53e755a.png 3 I% m$ i% r7 ~. v
3 H: L( O( ]. s, i
RCC外设时钟使能寄存器
, d9 ]" a* V2 l; |# ?8 YAHBENR AHB外设时钟使能寄存器6 M8 w5 r6 O  Z/ x0 B. W+ S6 u
包括SDIO,FSMC,CRC,FLITF,SRAM,DMA1,DMA2
6 I2 ?) a# J1 j4 Q
# x' h9 Y: j- D! M
6bc5947e2ade4e11a3932fa655659f4a.png - \$ g4 _+ r! i' p- X
, a, c0 K( R* A1 r4 C
2e3c85c1ad1c4c129962e4eede3a4e2c.png 5 K! X1 t4 M" M9 A7 Q2 q0 y
% x8 f5 E# g; ~; f/ G& c
APB2ENR APB2外设时钟使能寄存器
1 _8 t4 ?1 ~# y. c4 g" A" ~  n 包括ADC3,USART1,TIM8,SIP1,TIM1,ADC2,ADC1,IO ABCDEFG等
) B' _  n3 y  Y* p# V2 k; K" U
cda89437598745288343d4382b0d3eaf.png
( h- m" y0 r9 u' C5 Y5 y1 e3 g- l! h7 B2 r6 Y
d2308d5111c447f5874938378a6f5fb8.png
/ F- S( u" c2 [0 W' L
9 d. {* U2 I1 b

* O9 F- h1 @  _. _, b 0768d25641454a7382bbf06dd145f662.png
, h, f* R* t" f& D: C' z
4 b& @) f- ^3 i" J- {! ?; P
APB1ENR APB1外设时钟使能寄存器
; y- |- f8 |  ?! x包括DAC接口,电源接口,备份接口,CAN时钟,USB时钟,I2C时钟,UART2345时钟,SPI23时钟,看门狗时钟,Timer 234567时钟等4 U5 v* S* v. Q% q  P- K" _, U2 f  E
* O& h# C# x! j: r# j
56a3d818a8794e08bb27a85a72e85844.png ! u% ]$ {& o8 n; [

$ d- B) Q4 i; _
021834f2395b48cbae24197de9f8abe0.png
2 `0 Z3 v7 u2 @  }" F# F* A
0 a4 M9 p2 \# r/ v
bd0a2909dca1438496c594a3f183171e.png
2 v$ A3 Q' g1 z' T* n9 Y, ~( X! ] 5 g* J# @' J6 Z  g  Z; _; f9 W
72949a1987ba4e1cb28c4ee51e46b116.png 3 j  ~7 s; N0 |. @% v( y# i  Q
7 D$ s' d* `4 j/ }% w
RCC寄存器的操作
# q; t# R" H$ G" c( }可以通过相关的库函数,对于这些RCC寄存器进行操作
" q2 A* e" p- P; g
8 b) B: l3 Z3 A2 ~* H  z" V& K
b5a3ccb26dce4dd796b258f4d6b8c43d.png ; |. f8 ]1 a, M& K4 x( |

4 e4 _0 U' r! g/ H% l4 x; q这些库函数可以分为以下几类:
3 l- ?& \, l2 Q( ^2 q7 t) o/ L! Y+ ?, \" J! f) q9 I

2 y; z6 X. `* I6 h9 Q) F1 f时钟使能配置. d% ]- l' H. T, b6 q/ [

( ~. I, H: @9 Vvoid RCC_LSEConfig(uint8_t RCC_LSE);! ]5 y/ k  t4 K: X
& {: ]1 f& P1 i' H+ v
void RCC_HCLKConfig(uint32_t RCC_SYSCLK);
% x6 o9 G( \( `6 \8 Y) {2 r2 E# \

- |1 T% S( \( H3 evoid RCC_HSEConfig(uint32_t RCC_HSE);
% o# \0 N" M& c- r/ R
0 t4 X; `% P% w* d- r
void RCC_HSICmd(FunctionalState NewState);
' d" m8 C) |: q! Q4 B+ [6 B7 w! O3 L+ Q
void RCC_LSICmd(FunctionalState NewState);' z* j& ]4 \7 d% k6 k# y8 s
, F* [% g7 M% E3 ]# N! r7 F: H  k
...
, z) d  v1 ^4 ?$ w
& P  C$ `* u& y' Y! {- z# Q
  o7 G* y2 P& [5 w4 k
时钟来源配置# Z- l4 f8 d, S! a

( j  @, n# S8 u% b& evoid RCC_PLLConfig(uint32_t RCC_PLLSource, uint32_t RCC_PLLMul);, Q3 X& p: j: n' R& a4 f; y3 k
5 ]2 @6 l+ h6 m  ~
void RCC_SYSCLKConfig(uint32_t RCC_SYSCLKSource);% n- g, S8 R6 K& l* w
4 B7 q- ^/ W  U" z
void RCC_RTCCLKConfig(uint32_t RCC_RTCCLKSource);
' w: @+ K% R) d

, d; j* e" N) ^# _- ?* y* b% d分频系数选择配置) J. V2 l8 j) ?* i% N1 r: A& C  Y. p0 v
/ m* @( m- Q: B' ?: d6 ]- t
void RCC_HCLKConfig(uint32_t RCC_SYSCLK);( `& ~1 D3 b' [, ^+ Z$ L) [
0 ~. v# _* N; V4 T# s0 z' o
void RCC_PCLK1Config(uint32_t RCC_HCLK);
2 T1 v8 g) m5 H2 Z+ L% }0 S3 z* b
$ a6 @- [1 }, ]% c6 W$ r1 _
void RCC_PCLK2Config(uint32_t RCC_HCLK);
, X$ ^* h: U' S. z7 Y! g! ~$ n( p' x. }8 M7 R  }5 P' Y
9 g( c# v8 u' E( y( ?. e
外设时钟使能
1 R, e# X2 {/ h4 p2 @# H" k  w

$ j7 ]3 f, H1 ^' dvoid RCC_APB1PeriphClockCmd(uint32_t RCC_APB1Periph, FunctionalState NewState);) g" G; b0 k  C0 k9 t# {/ D0 q
6 L2 y% z  [3 O
void RCC_APB2PeriphClockCmd(uint32_t RCC_APB2Periph, FunctionalState NewState);
( @( d( h* c9 L
7 T" {3 g, K' k' A3 M7 E6 Ivoid RCC_AHBPeriphClockCmd(uint32_t RCC_AHBPeriph, FunctionalState NewState);
5 t' D( e) Q0 a- u, a
4 a- x! W1 K5 ?
其他外设时钟配置
1 g* V- O  ^9 \; y

/ b% M$ Q( c  t& vvoid RCC_USBCLKConfig(uint32_t RCC_USBCLKSource);
: p5 ?$ C( a# k; I* q' j  Q. C6 U* _6 |) v, O
void RCC_ADCCLKConfig(uint32_t RCC_PCLK2);9 t! M, g( e9 h/ Y" n- a

3 e  a$ E/ C9 `状态参数获取
1 e# p/ k, K! Q* N+ M8 D
' Q- y/ p' D$ {% ]  ^6 zvoid RCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks);
1 {8 F1 [* z! A! G8 ^" p

; ]- N$ K5 P! i4 buint8_t RCC_GetSYSCLKSource(void);: }' h7 k- W4 r+ g
# D  D8 a# x8 s8 ~. }
FlagStatus RCC_GetFlagStatus(uint8_t RCC_FLAG);3 R; Q% `# a9 C5 r: i3 R6 U' Q' U
7 E3 S$ J& U. I! I0 I# B
RCC中断
; h# [- x6 g, D. q, z* Y. J( N2 |4 L2 j  o: G! [4 K
void RCC_ITConfig(uint8_t RCC_IT, FunctionalState NewState);) z! a, t, Q) U$ w. {

# W# I/ H# K  z6 n* b+ N3 I4 kITStatus RCC_GetITStatus(uint8_t RCC_IT);8 o0 t- @( S+ _" y
7 H- g! A7 X: A! T* @
void RCC_ClearITPendingBit(uint8_t RCC_IT);
! u/ D" I0 x5 M; `6 v, {! Z————————————————. Q  v* I# ~' G) ?& k% K
版权声明:CodeForCoffee# g) f' w5 o, |) h1 ^# l
. P4 H: b' I  F( q- F& J
收藏 评论0 发布时间:2022-12-27 18:00

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版