0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

一文详解STM32的时钟系统

jf_52bVvS8T 来源:STM32嵌入式开发 2023-02-24 18:07 次阅读

STM32时钟

时钟信号推动单片机内各个部分执行相应的指令,时钟就像人的心跳一样。

STM32本身十分复杂,外设非常多,任何外设都需要时钟才能启动,但并不是所有的外设都需要系统时钟那么高的频率,如果都用高速时钟势必造成浪费。同一个电路,时钟越快功耗越大、抗电磁干扰能力越弱。复杂的MCU采用多时钟源的方法来解决这些问题。如下图,是STM32的时钟系统框图。

d34a4e30-b41a-11ed-bfe3-dac502259ad0.png

如上图左边的部分,看到STM32有4个独立时钟源,HSI、HSE、LSI、LSE。

HSI是高速内部时钟,RC振荡器,频率为8MHz,精度不高。

HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~16MHz。

LSI是低速内部时钟,RC振荡器,频率为40kHz,提供低功耗时钟。

LSE是低速外部时钟,接频率为32.768kHz的石英晶体。

时钟树的右边红色框中,则是系统时钟通过AHB预分频器,给相对应的外设设置相对应的时钟频率。

其中LSI、LSE是作为IWDGCLK(独立看门狗)时钟源和RTC时钟源使用。而HSI、HSE以及PLLCLK经过分频或者倍频作为系统时钟SYSCLK来使用。

PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或者HSE/2。倍频可选择为2~16倍,但是其输出频率最大不得超过72MHz。通过倍频之后作为系统时钟的时钟源。

配置时钟

默认时钟

Keil编写程序是默认的时钟为72Mhz,其实是这么来的:

外部高速晶振HSE提供的8MHz(大小与电路板上的晶振相关)通过PLLXTPRE分频器后,进入PLLSRC选择开关,进而通过PLLMUL锁相环进行倍频(x9)后,为系统提供72MHz的系统时钟SYSCLK。之后是AHB预分频器对时钟信号进行分频,然后为低速外设提供时钟。相关文章推荐:时钟失效之后,STM32还能运行?

内部RC振荡器HSI为8MHz,2分频后是4MHz,进入PLLSRC选择开关,通过PLLMUL锁相环进行倍频(最大x16)后为64MHz。

USB时钟

d3c7a1e6-b41a-11ed-bfe3-dac502259ad0.png

如上图,STM32的USB时钟不能超过48MHz,因此如果时钟源为72MHz,就需要进行1.5分频。

如果时钟源为48MHZ,则进行1分频即可。

把时钟信号输出到外部

d3dbe476-b41a-11ed-bfe3-dac502259ad0.png

STM32可以选择一个时钟信号输出到MCO脚(PA8)上,可以选择为PLL输出的2分频、HSI、HSE、或者系统时钟,可以把时钟信号输出供外部使用。

AHB分频器

如时钟树图右边的部分,系统时钟通过AHB分频器给外设提供时钟。从左到右可以简单理解为:

系统时钟->AHB分频器->各个外设分频倍频器->外设时钟的设置。

右边部分为:系统时钟SYSCLK通过AHB分频器分频后送给各模块使用,AHB分频器可选择1、2、4、8、16、64、128、256、512分频。其中AHB分频器输出的时钟送给5大模块使用:

内核总线:送给AHB总线、内核、内存和DMA使用的HCLK时钟。

Tick定时器:通过8分频后送给Cortex的系统定时器时钟。

I2S总线:直接送给Cortex的空闲运行时钟FCLK。

APB1外设:送给APB1分频器。APB1分频器可选择1、2、4、8、16分频,其输出一路供APB1外设使用(PCLK1,最大频率36MHz),另一路送给通用定时器使用。该倍频器可选择1或者2倍频,时钟输出供定时器2-7使用。

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。

APB1和APB2的对应外设

d3f9886e-b41a-11ed-bfe3-dac502259ad0.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中查看外设挂在哪个时钟下。

时钟监视系统(CSS)

d415788a-b41a-11ed-bfe3-dac502259ad0.png

另外,STM32还提供了一个时钟监视系统(CSS),用于监视高速外部时钟(HSE)的工作状态。倘若HSE失效,会自动切换(高速内部时钟)HSI作为系统时钟的输入,保证系统的正常运行。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6032

    文章

    44513

    浏览量

    632743
  • STM32
    +关注

    关注

    2265

    文章

    10870

    浏览量

    354716
  • 时钟树
    +关注

    关注

    0

    文章

    53

    浏览量

    10732
  • 时钟信号
    +关注

    关注

    4

    文章

    445

    浏览量

    28506
  • 时钟系统
    +关注

    关注

    1

    文章

    99

    浏览量

    11700

原文标题:详解STM32的时钟系统,收藏了

文章出处:【微信号:EE时间,微信公众号:EE时间】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    浅析STM32系统时钟RCC

    STM32系统时钟RCC详解(超详细,超全面)原创...
    发表于 08-11 07:44

    系统时钟RCC详解

    STM32系统时钟RCC详解(超详细,超全面)1什么是时钟时钟是单片机运行的基础,
    发表于 08-12 06:40

    STM32时钟系统学习

    时钟系统是处理器的核心,所以在学习STM32所有外设之前,认真学习时钟系统是必要的,有助于深入理解STM
    发表于 08-12 08:31

    详解STM32时钟时钟信号

    详解STM32时钟系统STM32时钟时钟信号推
    发表于 08-19 06:33

    STM32时钟树案例详解

    STM32时钟树案例详解时钟树直接使用HSI作为时钟源使用配置相应的结构体,最后调用HAL_RCC_OscConfig(), 和HAL_RC
    发表于 08-20 06:11

    学习STM32时钟系统

    我在原创的基础又从另位博主处引用了些内容。时钟系统是处理器的核心,所以在学习STM32所有外设之前,认真学习
    发表于 08-23 07:23

    详解STM32时钟系统

    STM32为什么要有复杂的时钟系统呢?STM32有几个时钟源呢?
    发表于 11-05 07:46

    STM32系统时钟框架图

    STM32系统时钟框架图,能够帮你详细了解STM32单片机时钟
    发表于 08-18 18:24 19次下载

    STM32最小系统时钟详解

    最小系统1,、供电电路2、复位电路3、时钟:外部晶振(2个)4、Boot启动模式选择5、下载电路(JTAG)6、后背电池时钟详解:在STM32
    发表于 11-17 15:36 12次下载
    <b class='flag-5'>STM32</b>最小<b class='flag-5'>系统</b>和<b class='flag-5'>时钟</b><b class='flag-5'>详解</b>

    STM32L4系列时钟系统简介

    跟着原子哥学习,顺便写点笔记~主要内容1)STM32L4 时钟树概述;2)STM32L4 时钟初始化配置;3)STM32L4
    发表于 11-21 18:36 21次下载
    <b class='flag-5'>STM32</b>L4系列<b class='flag-5'>一</b>、<b class='flag-5'>时钟</b><b class='flag-5'>系统</b>简介

    STM32STM32F4时钟系统

    STM32F4时钟系统概述时钟系统是 CPU 的脉搏,就像人的心跳样。所以
    发表于 11-25 20:06 46次下载
    【<b class='flag-5'>STM32</b>】<b class='flag-5'>STM32</b>F4<b class='flag-5'>时钟</b><b class='flag-5'>系统</b>

    STM32系统时钟RCC详解

    STM32系统时钟RCC详解(超详细,超全面)
    发表于 11-30 12:21 14次下载
    <b class='flag-5'>STM32</b><b class='flag-5'>系统</b><b class='flag-5'>时钟</b>RCC<b class='flag-5'>详解</b>

    【自学笔记】STM32时钟系统详解

    ,ADC),时钟的重要性不言而喻。为什么STM32要有多个时钟源呢?​ STM32本身十分复杂,外设非常多 但我们实际使用的时候只会用到有限的几个外设,使用任何外设都需要
    发表于 12-09 13:21 11次下载
    【自学笔记】<b class='flag-5'>STM32</b><b class='flag-5'>时钟</b><b class='flag-5'>系统</b><b class='flag-5'>详解</b>

    2.STM32的存储器、电源和时钟体系

    部分、章节目录3.2.1.STM32的存储器映像13.2.2.STM32的存储器映像23.2.3.STM32的位带操作详解3.2.4.
    发表于 01-07 15:32 1次下载
    2.<b class='flag-5'>STM32</b>的存储器、电源和<b class='flag-5'>时钟</b>体系

    STM32时钟系统时钟启动顺序详解

    STM32时钟系统基本致,不同系列之间有细微差别。此文档主要针对STM32F446的时钟
    发表于 02-09 10:31 6次下载
    <b class='flag-5'>STM32</b><b class='flag-5'>时钟</b><b class='flag-5'>系统</b>与<b class='flag-5'>时钟</b>启动顺序<b class='flag-5'>详解</b>