
概述 STM32时钟系统主要的目的就是给相对独立的外设模块提供时钟,也是为了降低整个芯片的耗能。3 ^" R5 C, B& h" R- l& g 系统时钟,是处理器运行时间基准(每一条机器指令一个时钟周期)3 R, m$ _6 [8 q' O0 _+ Z 时钟是单片机运行的基础,时钟信号推动单片机内各个部分执行相应的指令。 一个单片机内提供多个不同的系统时钟,可以适应更多的应用场合。$ d! O3 _. e8 {+ ^ 不同的功能模块会有不同的时钟上限,因此提供不同的时钟,也能在一个单片机内放置更多的功能模块。 对不同模块的时钟增加开启和关闭功能,可以降低单片机的功耗 STM32为了低功耗,他将所有的外设时钟都设置为disable(不使能),用到什么外设,只要打开对应外设的时钟就可以, 其他的没用到的可以还是disable(不使能),这样耗能就会减少。 这就是为什么不管你配置什么功能都需要先打开对应的时钟的原因3 t' B8 {0 e8 M/ k% ~ ![]() 各个时钟源 (左边的部分)7 ~- y, z4 @4 [8 F4 U STM32G0有4个独立时钟源:HSI、HSE、LSI、LSE。 ①、HSI是高速内部时钟,RC振荡器,频率为16MHz,精度不高。4 K c$ e! |9 M2 r% ~! Z- n4 [ { ②、HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~48MHz。 V2 V! G1 r3 u. u1 S' ]6 H. I4 F; A1 @5 \ ③、LSI是低速内部时钟,RC振荡器,频率为32kHz,提供低功耗时钟。 ④、LSE是低速外部时钟,接频率为32.768kHz的石英晶体。 6 ?9 c; `! |+ ?4 @3 ] 其中LSI是作为IWDGCLK(独立看门狗)时钟源和RTC时钟源 而独立使用 6 ]5 O& ^1 b8 s7 X" Z. I % _& A. X ?2 ~) o8 r2 ?6 M 而HSI高速内部时钟、 HSE高速外部时钟、 LSI低速内部时钟,这三个经过分频或者倍频 作为系统时钟来使用- O9 p1 Q( c1 @7 R0 i PLL为锁相环倍频输出,基于HSI16或基于HSE的时钟的频率相乘,以产生三个独立的时钟输出。允许的输入频率范围是2.66至16 MHz。分频因子可从1到8进行编程0 |) e7 {# l7 [% `/ V 时钟分析3 k$ {3 c# |) U& B% I$ N LSI(低速内部时钟)1 N0 @7 f# s+ I" u 8 K# R9 Q5 d' X 作为IWDG(独立看门狗)和RTC的时钟源,单独使用。 4 x# M- K, I/ ~ LSE(低速外部时钟)( J K- P0 J- e6 y$ } B 可以为RTC、CEC、SYSCLK提供时钟源。 HSE(高速外部时钟) ) U2 G, |- B: z B: g 可以为RTC、SYSCLK、PLL提供时钟源。 HSI(高速内部时钟) 2 h1 X: c8 P2 D1 q# s: Q 可以为PLL、HSISYS提供时钟源,HSISYS再为SYSCLK提供时钟源 3 N4 s- I/ z, Z$ b) \9 ~3 ^; r1 I PLL(锁相环倍频输出) 由HSE、HSI输入,经过分频倍频后提供SYSCLK,还用两组时钟分别提供给TIM1/TIM15/RNG和ADC/I2S1。 其他时钟源分析 HSISYS, z7 h9 F6 C: B. p7 x6 T+ Z; N& m 从HSI16通过除以1到128的可编程因子得到的时钟) `8 z+ z% W# z) c& r PLLPCLK,PLLQCLK,PLLRCLK . B2 P) \( H. s9 ]" z6 I 从PLL模块输出的时钟* V6 Z1 K# U; M0 _0 l3 a SYSCLK: g' }+ g: Q6 q$ I. ?' k# V) v 通过选择LSE,LSI,HSE,PLLRCLK和HSISYS时钟之一获得的时钟,是整个系统时钟基准。G0系列频率最高到64MHz。 , h8 h; r8 ^0 r5 X x e5 [ HCLK" w4 R; C: s: N # y5 I& y2 B5 d' F 由SYSCLK通过除以从1到512可编程的因子得出的时钟 HCLK8 + i" {; C' G2 v; h: ^ 由HCLK八分频得出的时钟 7 q% a! j5 @/ ~9 R5 X% `( q PCLK . o& A6 C3 s* l0 L4 U" @ 从HCLK的时钟通过除以从1到16可编程的因子得出的时钟 TIMPCLK 从PCLK派生的时钟,如果APB预分频器分频因子设置为1,则以PCLK频率运行,否则,以PCLK频率的两倍运行 LPTIMx_IN, W2 M4 y0 _& R+ S j, S, R0 R* k9 U$ C7 O LPTIMx_INx引脚提供的时钟,可为LPTIM外设选择 MCO(微控制器时钟输出) 微控制器时钟输出(MCO)功能允许将时钟输出到外部MCO引脚。 可以选择以下之一作为MCO时钟:& l% r6 e; P" y2 r • LSI • LSE • SYSCLK) ~' f. F* J& D+ F! u/ I% g4 O# ?; v • HSI16 • HSE4 |7 K7 F# Q! {8 w$ p. A1 D+ ^ • PLLRCLK CSS(时钟安全系统)' s& g4 C8 Y2 i1 u% u 时钟安全系统可以通过软件激活。一旦检测到HSE时钟故障,则系统时钟将自动切换到HSISYS,并且禁用HSE振荡器。如果HSE时钟也是PLL的时钟来源,并且发生故障时将PLLRCLK用作系统时钟,则PLL也被禁用。$ x& H4 K D7 }- q5 {# O7 N 7 A2 N: L' `: E, Y# A( D! d9 O0 q+ [, U 通过CubeMX配置时钟树 新建工程,并且开启SWD调试 ;(如何开启SWD调试,请点击链接) 通过在引脚视图界面,配置PC6为GPIO_Output;(如何使用GPIO引脚,请点击链接)1 L& ~' D7 R( [! P: h1 C& D! U/ B5 Z 在Pinout&Configuration中选中"RCC",在配置栏High Speed Clock(HSE)下拉菜单中选中"Crystal/Ceramic Resonator"4 h Q: ?0 ~6 L) W i" o' r- a ![]() 3 T# q( I: I& K4 z$ _- h& N 在Clock Configuration中 ,按下图配置,在HCLK框中输入最大64MHz,回车。cubemx软件会自动计算系数,而不用手动填写。保持激活CSS。6 e$ [+ o& A$ j5 k + K- W" y) C9 l* P6 R% _4 r* f ![]() 6 B+ V0 j+ r2 n 然后在Project Manager中,设置好参数信息。 ![]() : `( |. i# B' f2 @ ![]() 最后点击GENERATE CODE,生成工程文件。 打开工程项目,进入到MDK软件 ![]() ) D2 i6 Y. I3 Q: F( t. B0 f) j 打开魔术棒工具-Debug-Settings-Flash Download,勾上"Reset and Run",最后就可以编写代码,自由发挥吧。 5 V4 a# T0 @) p! J ![]() + E* _' Y- O/ X ———————————————— 版权声明:SCCELE0 E) I- \) N6 w# x- H . }/ e: ^6 R w P |