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

【经验分享】详解STM32的时钟系统

[复制链接]
STMCU小助手 发布时间:2022-6-21 19:30
STM32的时钟树
    时钟信号推动单片机内各个部分执行相应的指令,时钟就像人的心跳一样。
    STM32本身十分复杂,外设非常多,任何外设都需要时钟才能启动,但并不是所有的外设都需要系统时钟那么高的频率,如果都用高速时钟势必造成浪费。同一个电路,时钟越快功耗越大、抗电磁干扰能力越弱。复杂的MCU采用多时钟源的方法来解决这些问题。如下图,是STM32的时钟系统框图。
XI`%$T[UZZ9[__J6UKBB60O.png
    如上图左边的部分,看到STM32有4个独立时钟源,HSI、HSE、LSI、LSE。
2 @7 M% d# l7 _/ a, U
  • HSI是高速内部时钟,RC振荡器,频率为8MHz,精度不高。% U1 s) o4 Q8 H2 v; T% w* F) J
  • HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~16MHz。3 B( N/ W0 T9 L+ N7 p
  • LSI是低速内部时钟,RC振荡器,频率为40kHz,提供低功耗时钟。 - }* [7 U5 a: ?3 Y: H
  • LSE是低速外部时钟,接频率为32.768kHz的石英晶体。

    % v# O3 v! a7 S! q9 `
    时钟树的右边红色框中,则是系统时钟通过AHB预分频器,给相对应的外设设置相对应的时钟频率。
    其中LSI、LSE是作为IWDGCLK(独立看门狗)时钟源和RTC时钟源使用。而HSI、HSE以及PLLCLK经过分频或者倍频作为系统时钟SYSCLK来使用。
    PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或者HSE/2。倍频可选择为2~16倍,但是其输出频率最大不得超过72MHz。通过倍频之后作为系统时钟的时钟源。

( A: B% X2 ^0 D4 W5 v' }: d, u- a
配置时钟
' f. H- t- j2 J9 M$ W! C9 X
默认时钟
1 u/ V# m9 f2 p
    Keil编写程序是默认的时钟为72Mhz,其实是这么来的:
    外部高速晶振HSE提供的8MHz(大小与电路板上的晶振相关)通过PLLXTPRE分频器后,进入PLLSRC选择开关,进而通过PLLMUL锁相环进行倍频(x9)后,为系统提供72MHz的系统时钟SYSCLK。之后是AHB预分频器对时钟信号进行分频,然后为低速外设提供时钟。
    内部RC振荡器HSI为8MHz,2分频后是4MHz,进入PLLSRC选择开关,通过PLLMUL锁相环进行倍频(最大x16)后为64MHz。

( b( M. @7 a0 b; v& ~- l: [
USB时钟
8`WCY]CP])E_8M@9SDL}@9T.png
    如上图,STM32的USB时钟不能超过48MHz,因此如果时钟源为72MHz,就需要进行1.5分频。
    如果时钟源为48MHZ,则进行1分频即可。

/ d; D- f! m( C' X% X5 D/ |, E
把时钟信号输出到外部
HMYG%WXTZUSY2M_BG631Y~O.png
    STM32可以选择一个时钟信号输出到MCO脚(PA8)上,可以选择为PLL输出的2分频、HSI、HSE、或者系统时钟,可以把时钟信号输出供外部使用。

3 m1 @4 N! H& ]9 {5 S5 s- _
AHB分频器 如时钟树图右边的部分,系统时钟通过AHB分频器给外设提供时钟。从左到右可以简单理解为:    系统时钟->AHB分频器->各个外设分频倍频器->外设时钟的设置。
    右边部分为:系统时钟SYSCLK通过AHB分频器分频后送给各模块使用,AHB分频器可选择1、2、4、8、16、64、128、256、512分频。其中AHB分频器输出的时钟送给5大模块使用:
  • 内核总线:送给AHB总线、内核、内存和DMA使用的HCLK时钟。
    ' S+ U8 T, g$ J7 U2 J/ O% \* n
  • Tick定时器:通过8分频后送给Cortex的系统定时器时钟。 , k' @- M: B. \0 |3 Z
  • I2S总线:直接送给Cortex的空闲运行时钟FCLK。 7 ^3 w: T! P$ Q' j8 R5 i' i
  • APB1外设:送给APB1分频器。APB1分频器可选择1、2、4、8、16分频,其输出一路供APB1外设使用(PCLK1,最大频率36MHz),另一路送给通用定时器使用。该倍频器可选择1或者2倍频,时钟输出供定时器2-7使用。 ' L/ Q. `5 [* w7 q
  • APB2外设:送给APB2分频器。APB2分频器可选择1、2、4、8、16分频,其输出一路供APB2外设使用(PCLK2,最大频率72MHz),另一路送给高级定时器。该倍频器可选择1或者2倍频,时钟输出供定时器1和定时器8使用。另外,APB2分频器还有一路输出供ADC分频器使用,分频后送给ADC模块使用。ADC分频器可选择为2、4、6、8分频。需要注意的是,如果APB预分频器分频系数是1,则定时器时钟频率(TIMxCLK)为PCLKx。否则,定时器时钟频率将为 APB 域的频率的两倍:TIMxCLK = 2xPCLKx。
    ; i$ e* Q. N/ n, \+ B. u
APB1和APB2的对应外设
SBNW7]@{L_{6_72P}{[W($A.png
    F1系列中,APB1上面连接的是低速外设,包括电源接口、备份接口、CAN、USB、I2C1、I2C2、USART2、USART3、UART4、UART5、SPI2、SP3等。
    APB2上面连接的是高速外设,包括UART1、SPI1、Timer1、ADC1、ADC2、ADC3、所有的普通I/O口(PA-PE)、第二功能I/O(AFIO)口等。
    具体可以在stm32f10x_rcc.h中查看外设挂在哪个时钟下。

) S& z) R. i' _) P& u
时钟监视系统(CSS)
VG[66@AZD`TWB3V8Z5FI06I.png
    另外,STM32还提供了一个时钟监视系统(CSS),用于监视高速外部时钟(HSE)的工作状态。倘若HSE失效,会自动切换(高速内部时钟)HSI作为系统时钟的输入,保证系统的正常运行。
' o5 O6 w" \; ?7 C; s
1 A8 @! U8 U- }
收藏 评论0 发布时间:2022-6-21 19:30

举报

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