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

【经验分享】STM32学习心得七:STM32时钟系统框图及相关函数解读

[复制链接]
STMCU小助手 发布时间:2021-12-4 20:04
记录一下,方便以后翻阅~& C6 n# q& q; i( ]
主要内容:% N. z# M: O8 A
1) 时钟系统框图解读;
- q3 y0 j0 z# g2) 时钟系统配置相关函数解读。$ X' K3 D2 V' G
官方资料:《STM32中文参考手册V10》第六章 复位和时钟控制 RCC. g5 M# g( C0 b! I7 ^( W) g8 B! J
1. 为什么 STM32 要有多个时钟源呢?0 p/ G  v+ c0 e' t( r2 `; A
因为STM32非常复杂,外设多,但并不是所有外设都需要系统时钟这么高的频率,比如看门狗及RTC只需要几十k的时钟即可。同一电路,时钟越快功耗越大,同时抗电磁干扰能力也会越弱,所以对于较为复杂的MCU一般采取多时钟源的方法来解决这些问题。
% c& p: d# ]' |) h" Q2. 时钟系统框图解读
6 h$ S5 s1 Y$ X* O0 w) c  E& W# ~5 j  l, H4 H3 D% p2 `( R
20200331141029586.png

$ v3 m0 y: L$ B1 p. C1) STM32 有5个时钟源:HIS(High Speed Internal)、HSE(High Speed External)、LSI(Low Speed Internal)、LSE(Low Speed External)、PLL:
5 S9 a0 n  d5 |- O* u1.1 HSI是高速内部时钟,RC振荡器,频率大约为8MHz,精度不高,可作为系统时钟;
; @( u8 t7 r' [; u8 v1.2 HSE是高速外部时钟,可接石英/陶瓷谐振器,或接外部时钟源,频率范围为4MHz~16MHz;" Q6 b: @: }% ~& F4 [1 G
1.3 LSI是低速内部时钟,RC振荡器,频率为40kHz,提供低功耗时钟。独立看门狗的时钟源只能是LSI,同时LSI还可以作为RTC的时钟源;9 C5 V4 W3 d& i6 l0 O. A/ p
1.4 LSE是低速外部时钟,接频率为32.768kHz的石英晶体,主要作为RTC的时钟源;
4 c0 k. |' N4 ?; u7 f; q- n0 i1.5 PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或HSE/2。倍频可选择为2~16倍,但其输出频率最大不得超过72MHz。
6 N; U# Q2 Q2 Q2) MCO是STM32的一个时钟输出IO(接在PA8引脚上),可选择一个时钟信号输出,(如PLL输出的2分频、HSI、HSE、或者系统时钟),这个时钟可用来给外部其他系统提供时钟源;
$ m; v9 U+ P% g( J& @  e& Z5 M( I3) RTC时钟源可选择LSI,LSE,及HSE的128分频;, S0 i4 s  m" n4 d! E
4) USB的时钟来自PLL时钟源,STM32中有一个全速功能的USB模块,其串行接口引擎需要一个频率为 48MHz的时钟源。该时钟源只能从PLL输出端获取,可选为1.5分频或1分频,即当需要使用USB模块时,PLL必须使能,且时钟频率配置为48MHz或72MHz;
5 Q0 l2 h% G1 k2 C# V+ w% J1 u" ?% q. i5) 系统时钟SYSCLK供STM32中绝大部分部件工作的时钟源。系统时钟SYSCLK可选为PLL输出、HSI或HSE。最大频率为72MHz;
1 r% Y7 B8 v4 X8 E4 N6) 其他外设的时钟来源都是SYSCLK。SYSCLK通过AHB分频器分频后送给各模块使用,包括:# g& Q& N+ a, V5 d
6.1 AHB总线、内核、内存和DMA使用的HCLK时钟;! `. t( y0 s9 g- ^! O
6.2 通过8分频后送给Cortex的系统定时器时钟,即systick;" a6 e, [" n7 P& D3 j. A- a
6.3 直接送给Cortex的空闲运行时钟FCLK;
6 z/ e8 B/ A* S6.4 送给APB1分频器。APB1分频器输出一路供APB1外设使用(PCLK1,最大频率36MHz),另一路送给定时器(Timer)2、3、4倍频器使用;
; n3 t$ g& c  d) u( Q) V6.5 送给APB2分频器。APB2分频器分频输出一路供APB2外设使用(PCLK2,最大频率72MHz),另一路送给定时器(Timer)1倍频器使用。; \6 F( B/ R" ?3 T2 R" D. f( Z
7) APB1上面连接的是低速外设,包括电源接口、备份接口、CAN、USB、I2C1、I2C2、UART2、UART3等等,APB2上面连接的是高速外设包括UART1、SPI1、Timer1、ADC1、ADC2、所有普通 IO 口(PA~PE)、第二功能IO口等;9 D( c; l% E2 O5 I& S) |/ e8 M
8) CSS时钟监视系统,一旦HSE失效,自动切换至SYSCLK=HIS;1 u" S5 Y8 L8 s7 A7 O
9) 任何一个外设在使用之前,必须首先使能其相应的时钟;8 `1 S3 X/ m0 W7 ~: J8 [: _2 _; [
10) 5个主要的时钟:
5 _/ g  x; {; F: ^7 u+ m$ w+ P10.1 SYSCLK(系统时钟);4 q. Q6 \# G, n, i% {7 F% d1 d
10.2 AHB总线时钟;
: N( m7 ?, e8 g& k. i% p; C10.3 APB1总线时钟(低速): 速度最高36MHz;* g; o' E* Q( [6 n3 m/ W. p$ b
10.4 APB2总线时钟(高速): 速度最高72MHz;
  z. R! D% M- ~4 U4 x% ^10.5 PLL时钟。, M5 i2 M. R) V
3. 时钟相关配置寄存器
( R/ v: |; i: x) B2 ]* \, I" |2 v
  1. typedef struct
    & D& x8 d. v; w8 m! z9 q
  2. {* \+ v7 Y: v) q+ b1 x
  3.   __IO uint32_t CR;                //HSI,HSE,CSS,PLL等的使能和就绪标志位 : ~% [8 `0 k, i
  4.   __IO uint32_t CFGR;             //PLL等的时钟源选择,分频系数设定
    * @- c& ^' z' H4 s6 F6 \! w
  5.   __IO uint32_t CIR;               // 清除/使能 时钟就绪中断8 `4 d$ F0 U& I
  6.   __IO uint32_t APB2RSTR;        //APB2线上外设复位寄存器
    5 Z& z: m" @& T9 C, U
  7.   __IO uint32_t APB1RSTR;        //APB1线上外设复位寄存器
    * j% O; }& O2 ?7 q" p! @
  8.   __IO uint32_t AHBENR;          //DMA,SDIO等时钟使能 9 i* a6 I+ c) k: i
  9.   __IO uint32_t APB2ENR;         //APB2线上外设时钟使能   F) E5 L: H9 d4 p
  10.   __IO uint32_t APB1ENR;         //APB1线上外设时钟使能
    6 A3 Z4 i, J7 m
  11.   __IO uint32_t BDCR;            //备份域控制寄存器- y" D, n4 O8 D; c6 d  a; i
  12.   __IO uint32_t CSR;             //控制状态寄存器
    6 \- ~4 I% L" f2 E# n1 h
  13. } RCC_TypeDef;
复制代码
4. RCC相关头文件和固件库源文件; D) C+ n7 f, X  h% S' c
4.1 时钟使能配置:3 n$ m2 m  Y7 P  [% v
RCC_LSEConfig() 、RCC_HSEConfig()、RCC_HSICmd() 、 RCC_LSICmd() 、 RCC_PLLCmd() ……& a7 G1 [, c# G
4.2 时钟源相关配置:
" a  D' H! U! r' Q, FRCC_PLLConfig ()、 RCC_SYSCLKConfig() 、RCC_RTCCLKConfig() …
& r( p# b. @" Y0 J: w4 p4.3 分频系数选择配置:: c1 ?. H9 ^3 }4 }3 S
RCC_HCLKConfig()
: ~9 W( o/ B# D' v8 C+ X% C、 RCC_PCLK1Config() 、 RCC_PCLK2Config()…
+ x$ `( ^4 ?3 R6 b. p4.4 外设时钟使能:
+ Q2 o/ U2 f9 \2 U9 P
  1. RCC_APB1PeriphClockCmd();    //APB1线上外设时钟使能
    % o) N+ C" k& @# c5 M& v
  2. RCC_APB2PeriphClockCmd();    //APB2线上外设时钟使能$ C; H/ A7 h1 k/ U  m) p- X8 n
  3. RCC_AHBPeriphClockCmd();     //AHB线上外设时钟使能
复制代码
8 M5 z/ A% U! a$ }: T# |
4.5 其他外设时钟配置:
) D  i6 T: C" P/ k- L* |RCC_ADCCLKConfig()、RCC_RTCCLKConfig();
. V# [2 k& Z- ^& O( U4.6 状态参数获取参数:
5 J7 i3 R3 H& n. X/ Q( SRCC_GetClocksFreq()、RCC_GetSYSCLKSource()、RCC_GetFlagStatus();
: }. {. Q3 H# Y1 p6 X4.7 RCC中断相关函数:5 @  [  n7 g, a! m0 j. L
RCC_ITConfig()、 RCC_GetITStatus() 、 RCC_ClearITPendingBit()…
0 P/ a* p: l8 R# \& t& C  ^7 m3 R

5 f$ e* Z) ~$ F9 A2 z% K) }1 Y7 [0 h+ ~) o& V" R7 s: o/ V1 {
收藏 评论0 发布时间:2021-12-4 20:04

举报

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