STM32时钟体系结构

STM32时钟体系结构http://blog.youkuaiyun.com/qq_29344757/article/details/73479924

STM32的时钟体系可以直接以图概括(摘自STM32F10X参考手册) 
这里写图片描述
下面就此图做分析

1. STM32输入时钟源

1.1 时钟源的作用

无论是小型单片机还是像STM32这样高级单片机,它们工作的核心都是大规模的时序逻辑电路,而驱动时序逻辑电路的关键则是准确而又稳定的时钟源。它的作用就像小学在操场上做广播体操时候播放的背景音乐,用于协调和同步各单元运行,为时序电路提供基本的脉冲信号。

1.2 STM32时钟源的设计

在51单片机中,一般都外接一个11.0592MHz的晶振,注意,提供时钟的不是晶振,而是RC时钟电路,而晶振只是时钟电路的元件之一。同理,在STM32中,时钟源也是由RC时钟电路产生,与51单片机的区别是区别在于,RC电路的位置。根据RC电路的位置,可以将STM32的时钟源分为内部时钟电路和外部时钟、内外部时钟电路。 
(1)内部时钟电路: 
晶体振荡器和RC时钟电路都在STM32芯片内部,如图中标注1、标注4。 
标注1处是产生8MHz的时钟源,称为HSI,高速内部时钟源(H意为高速,S意为源,I意为内部); 
标注2处是产生32KHz的时钟源,称为LSI,低速内部时钟源; 
(2)内外部时钟电路: 
晶体振荡器在STM32芯片外部,RC时钟电路在STM32芯片内部,如图中标注2、标注3。 
标注2处是产生4-16MHz的时钟源,称为HSE,高速外部时钟源; 
标注3是产生32.768KHz的时钟源,称为LSE,低速外部时钟源; 
OSC_OUT和OSC_IN、OSC32_OUT和OS32_IN分别接晶振的两个引脚。前者一般接8MHz晶振;后者一定接32.768KHz,因为这个时钟源是供给RTC实时时钟使用的。在51单片机中没有集成RTC模块,在做电子时钟时用到的DS1302集成芯片时,也是为其提供的也是32.768KHz的晶振。 
(3)外部时钟电路 
晶体振荡电路和RC时钟电路都在STM32芯片外部。如图中标注2、标注3。 
OSC_OUT和OSC_IN、OSC32_OUT和OS32_IN除了分别接晶振的两个引脚,对于OSC_IN和OSC32_IN引脚,还可以接入外部的RC时钟电路,其时钟源直接由外部供给,不过这种方案少见。 
综上所述,STM32的时钟源有4个: HSI、HSE和LSI、LSE。 
HSI时钟源,它是在由STM32在内部用RC振荡电路实现的高速内部时钟源。HIS RC振荡器能够在不需要任何外部期间的条件下提供系统时钟,它的启动时间比HSE晶体振荡器短,但是不精准,即使在校准之后它的时钟频率精度仍较差。在手册中还明确说,当HSI被用作PLL时钟输入时,系统时钟能得到的最大频率是61MHz,这显然不能发挥STM32最极致的性能。

1.3 时钟信号通道选择

虽然HSI不精准,但是鉴于启动速度原因考虑,STM32上电复位,默认是采用HSI时钟源的,当然开发者可以不修改这个时钟源,那么系统将一直工作在一个时钟源不稳定不精准的环境下。 
然而一般做法是改变时钟源,将时钟源改为HSE。改变时钟源的通道是在相关寄存器设置的,在图中的PLLSRC可以实现对这两个频率的切换。 
这里写图片描述

1.4 锁相环倍频器PLL/预分频器Prescaler

STM32的cpu的工作常规频率是72MHZ(超过72MHz工作称为超频工作,CPU耗电加剧,且会发烫),但是我们接入的晶振是8MHz,这就需要一个对频率加倍的操作,即倍频。如图中的PLLMUL,PLLMULL实现对接入时钟源的倍频,如x2、x3、x4…倍频后的时钟源为PLLCLK。 
这里写图片描述 
预分频器是实现对频率削减作用的。倍频器将HSE倍频之后提供给cpu,但是除了cpu之外,其他片内外设,如SPI控制模块、IIC控制模块等的工作同样需要时钟源,这些外设的时钟源肯定是低于cpu运行时钟的,例如USB通讯才需要48MHz,所以需要对倍频后的时钟源进行分频。一般芯片的分频做法都是对一个时钟源倍频后供给某些部件,其他低于此倍频后的时钟都是基于此时钟源来分频的。用户可通过多个预分频器配置AHB,高速APB(APB2)和低速APB(APB1)域的频率。AHB和APB2域的最大频率是72MHz。APB1域的最大允许频率是36MHz。SDIO接口的时钟频率固定在HCLK / 2。 
经过时钟源的选择、分频/倍频,就可以到HCLK(高性能总线AHB用)、FCLK(供给cpu内核的用,常说的cpu主频)、PCLK(高性能外设总线APB)、USBCLK、TIMXCLK、TIM1CLK、RTCCLK等,外设是挂载STM32的总线上的,具体哪个外设挂载哪个总线,看下图: 
这里写图片描述
在软件开发中,我们要做的也无非设置门电路以选择时钟源输入、倍频/分频系数和打开/关闭对应外设所在总线的时钟。

2. STM32输出时钟源

图中的MCO功能模块,可以将PLLCLK / 2、HSI、HSE、SYSCLK输出,供给其他系统作为输入时钟源,对这一功能模块也是又相应的寄存器,图中以MCO标注。 
这里写图片描述

3. 系统滴答Systick

Systick就是一个定时器而已,只是它放在了NVIC中,主要的目的是为了给操作系统提供一个硬件上的中断,称之为滴答中断操作系统进行运转的时候,也会有时间节拍。它会根据节拍来工作,把整个时间段分成很多小小的时间片,而每个任务每次只能运行一个时间片的时间长度,超时就退出给别的任务运行,这样可以确保任何一个任务都不会霸占操作系统提供的各种定时功能,都与这个滴答定时器有关。因此,需要一个定时器来产生周期性的中断,而且最好还让用户程序不能随意访问它的寄存器,以维持操作系统的节拍。只要不把它在SysTick控制及状态寄存器中的使能位清除,就一直执行。 
这里写图片描述
RCC(复位与时钟控制器)通过AHB时钟(HCLK)8分频后作为Cortex系统定时器(SysTick)的外部时钟。通过对SysTick控制与状态寄存器的设置,可选择上述时钟或Cortex(HCLK)时钟作为SysTick时钟(后者图中没画出)。另外,还有其他时钟,如USB时钟,ADC时钟、独立看门狗时钟等,它们各自的时钟源通过前面学习,也可以轻易分析出来,这里不再赘述。

4. 时钟相关的寄存器

时钟体系涉及到的寄存器有

RCC_CR
RCC_CFGR
RCC_CIR
RCC_APB2RSTR
RCC_APB1RSTR
RCC_AHBENR
RCC_APB2ENR
RCC_APB1ENR
RCC_BDCR
RCC_CSR
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

这些寄存器的作用直接看数据可知,编程使用部分后续补充。

### STM32时钟体系结构详解 STM32微控制器系列采用了一种高度灵活且可配置的时钟系统架构,旨在满足不同应用场景的需求。这种设计允许开发者通过软件控制来调整系统的性能和功耗。 #### 1. 主要时钟STM32支持多种内部和外部时钟源: - **HSI (High Speed Internal)**:高速内置振荡器,默认频率为8 MHz,在上电复位后自动启动并提供初始时钟信号[^1]。 - **HSE (High Speed External)**:可通过连接晶体或陶瓷谐振器实现更高精度与时基稳定性,典型工作范围在4至26 MHz之间。 - **LSI (Low Speed Internal)**:低速内建RC振荡器,主要用于实时时钟(RTC),其默认频率约为32 kHz。 - **LSE (Low Speed External)**:同样用于RTC模块,一般选用32.768 kHz的标准晶振以获得更精确的时间基准。 #### 2. PLL (Phase-Locked Loop) 为了提高CPU的工作效率和支持更多周边设备的功能需求,STM32还配备了PLL锁相环电路。PLL可以从上述任一高频时钟源获取输入,并经过倍频处理生成更高的核心操作频率。例如,当使用HSE作为PLL入口时,可以通过设置寄存器参数使最终输出达到72 MHz的最大值。 ```c RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; RCC_OscInitStruct.HSEState = RCC_HSE_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9; // HCLK = SYSCLK / 1 = 72MHz HAL_RCC_OscConfig(&RCC_OscInitStruct); ``` 此代码片段展示了如何初始化HSE并通过PLL将其乘以9得到72 MHz的核心时钟速度。 #### 3. AHB/APB 总线及时钟分配机制 除了中央处理器本身之外,外围接口也需要稳定的时钟供给才能正常运作。为此,STM32定义了几条主要的数据传输路径及其对应的时钟树形结构——AHB(Advanced High-performance Bus)、APB1/2(Advanced Peripheral Bus)。这些总线上挂载着各类硬件资源,如DMA、定时器、ADC等,每一条都有独立于其他部分工作的能力,并能依据实际需要动态调节各自的运行速率。 #### 4. 时钟安全系统(CSS) 考虑到意外情况可能导致主时钟失效的风险,STM32特别加入了CSS特性。一旦检测到HSE停止振动,则会立即切换回更为可靠的HSI继续维持基本功能直至恢复正常供电状态或是触发相应的保护措施。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值