请选择 进入手机版 | 继续访问电脑版

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

STM32时钟控制RCC笔记

[复制链接]
STMCU小助手 发布时间:2023-3-9 14:18
一、复位
. p" u+ |) j1 w; }1.1、系统复位

8 E. [& r5 l: k+ B" T& a/ @        除了时钟控制器的RCC_CSR寄存器中的复位标志位和备份区域中的寄存器(见图4)以外,系统复位将复位所有寄存器至它们的复位状态。9 ?: `& U& r* N( ~+ v- q

, m% i' J9 r# }" X6 O: j
1d12ee51793e4a2ea45cf057efc45f98.png ; s' p' E0 m, J

1 W9 ]2 X5 u% w# Q) j. M8 a& t当以下事件中的一件发生时,产生一个系统复位:
( l. b/ A! s$ ^1.NRST引脚上的低电平(外部复位), p; V' _0 x( ~/ X" ?3 h
2.窗口看门狗计数终止(WWDG复位)
/ X! v. u! H# E) Y3.独立看门狗计数终止(IWDG复位)/ R+ a% x2 Y4 o; t
4.软件复位(SW复位)# ?' v# [0 z, \
5.低功耗管理复位
  p- L/ x5 D2 ?' m( t可通过查看RCC_CSR控制状态寄存器中的复位状态标志位识别复位事件来源。, f7 X' l3 a$ N) R6 r9 u4 R) }$ d
+ V; A$ S$ x  Y- F5 u- \( S( b
& P# U5 u. u! z4 z6 n) L. Z! Z
1.2 电源复位. N& n) n- T( c) J- J! i9 f3 b
        电源复位将复位除了备份区域外的所有寄存器。当以下事件中之一发生时,产生电源复位:# M% L' [% U$ G  j# `# z
1.上电/掉电复位(POR/PDR复位)
* z$ ?" e6 \5 y' v/ z2.从待机模式中返回4 \$ X6 b0 e0 e' H
电源复位将复位除了备份区域外的所有寄存器。(见图4)1 n5 J9 I- k' l8 q& S7 l

* ]8 [6 A3 I0 z4 ?% m
' o# C! a) f+ w9 _
1.3备份域复位3 V+ h; n; G) d- N& V
        备份区域拥有两个专门的复位,它们只影响备份区域(见图4)。当以下事件中之一发生时,产生备份区域复位:( x5 O8 o' _! S( Z4 V7 ?
1.软件复位,备份区域复位可由设置备份域控制寄存器 (RCC_BDCR)(见6.3.9节)中的 BDRST位产生。! S: \4 s9 |; z+ X$ R4 G
2.在VDD和VBAT两者掉电的前提下,VDD或VBAT上电将引发备份区域复位; o5 y0 L- d2 B, ]
二、时钟
, x; @+ F$ d0 [. s2 F
对于系统时钟输入配置与用途配置可以参考芯片数据手册的电气特性中工作条件:F1系列的
1 t+ G' q* m. X9 }0 ~; S# y5 ?8 c
d6f777d661334869a2b6be0a2dd31b9a.png
4 n. }( Q: `% x3 |. n* P" J4 m6 H4 V1 p" P
2.1、时钟来源

/ M4 X3 ^3 O! G) }- T* K三种不同的时钟源可被用来驱动系统时钟(SYSCLK):
0 P+ V" P, e$ B● HSI振荡器时钟(内部高速时钟),最高64MHz(F1系列,在PLL前经过了2分频)
5 A+ A! z. z3 h9 o) a: N; X3 o2 P● HSE振荡器时钟(外部高速时钟),最高可达72MHz(F1系列),F4是128MHz
/ C% l- ]1 j( z! o● PLL时钟(由HSI和HSE锁相环倍频得来)# ~- A' X% A: ^; i; t

% M& Z# `: q9 Q. b  x, Y& ?
5ab380c5542149d996c00b4092c4764c.png
% d5 H& _/ {, {8 D% H, q* z5 D( M8 r" N/ w
● 40kHz低速内部RC,可以用于驱动独立看门狗和通过程序选择驱动RTC。RTC用于从停机/ 待机模式下自动唤醒系统。2 A$ y& W4 w: {4 S
● 32.768kHz低速外部晶体也可用来通过程序选择驱动RTC(RTCCLK)3 c8 ]) ]2 i: Z; X
! |6 j7 P/ w- w' e/ `& Z) ]
3b13ff27648d46a3a74085fcb7bd1d31.png
- b9 }/ I; b! `1 \
  Y: O1 {% ~3 B& {) R# V4 {2.2、系统时钟的用途
6 T. ~- e/ u2 C# i! N& r+ x9 |4 e  d+ t( t
5f16e2b5f46f4febb50084bee7dfaee6.png . |3 h- k7 ?. d5 w9 C

  j2 i* Y' _* h9 a% G# }! q) P" r 2.3、为外部驱动提供时钟   

: a2 }1 }- E1 y' s 可以将时钟作为输出配置到引脚上,再用示波器查看相关的波形。
$ `1 R4 t% r& C8 j, q' S; ~9 {7 _! L; U3 @
1e2e2c0e966e44d9aaf18aa1a60d0e73.png
  z) A; X* C4 y
+ ?, x$ A+ @( q- W. H( G$ J& {
af6f793476624565b4f9790ea1f2b156.png
2 o2 M' ]7 M$ B9 u6 m2 O
( H. i4 `9 p" Z* E) m三、时钟配置(RCC)
, ^- g1 Y4 m% H7 _; @$ \        电路频率越高相应的电路中间态时间就越长,其功耗也会随之变高,可以通过控制任一个时钟源都可以被独立的启动或关闭,由此优化系统功耗。7 h2 P7 x/ _" _2 t% o0 L. `; ~) q

$ G8 K1 L% Q1 [# j2 d3.1、STM32CubeMX软件配置生成时钟配置代码
+ f# v, s; U, |% _! w5 h
  1. void SystemClock_Config(void)& [. P! P: T0 C& c. X
  2. {$ ?& o5 z- _. G0 V4 w* ^8 V4 k6 K! {$ P
  3.   RCC_OscInitTypeDef RCC_OscInitStruct = {0};4 i' P9 L8 z& H
  4.   RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};0 z5 y$ J0 C! z" H- }& w

  5. # e0 Q+ K# {2 l7 n2 y3 b6 ?2 ]
  6.   /** Initializes the RCC Oscillators according to the specified parameters
    9 s! U9 @  ^: G. |
  7.   * in the RCC_OscInitTypeDef structure.   通过RCC来配置系统时钟
    0 l+ [6 y8 i6 E- _
  8.   */
    1 e+ e! N) s: q
  9.   RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;! S* }% C' m2 J8 i$ K. V! T' H! u
  10.   RCC_OscInitStruct.HSEState = RCC_HSE_ON;1 L- z; \" [) d
  11.   RCC_OscInitStruct.HSEPredivValue = RCC_HSE_PREDIV_DIV1;
    : _% ~$ |- G5 y* ]: ?) _
  12.   RCC_OscInitStruct.HSIState = RCC_HSI_ON;
    # p% i, n  E" P, O: b
  13.   RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
    / F9 j2 A$ @1 {
  14.   RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
      S7 Z+ `. |" \8 c- `4 L
  15.   RCC_OscInitStruct.PLL.PLLMUL = RCC_PLL_MUL9;3 F# V$ }) @& A2 G1 k1 r
  16.   if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)( a- A3 N% }9 a2 a" d+ H; z
  17.   {5 H0 \6 F/ I4 O" Z8 a
  18.     Error_Handler();
    / C) m0 Y2 x" g' D. Q# c
  19.   }+ Q$ N$ ?  z) ~& I
  20.   /** Initializes the CPU, AHB and APB buses clocks+ c9 z( E( B0 f: f" }, F) ~4 o6 X
  21.     配置总线时钟,通过系统时钟而来! x9 [* y( d& s5 N6 J
  22.   */
    / p! i9 |8 R+ G: `3 G
  23.   RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
    * U. S9 H& I9 y3 t) M4 s+ l. z
  24.                               |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;* C. `; q1 y: \
  25.   RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
    : k- z9 J1 A2 f1 P2 z
  26.   RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
    . i( I! B% e# c" q
  27.   RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV2;
    % \! k6 m5 }3 G2 }3 X" `/ G
  28.   RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
    / |: F  V4 L: Q' x  S
  29. 0 K, V$ W2 c* H( k! _$ b" x
  30.   if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_2) != HAL_OK)
    3 ?0 J! L' f4 \5 |0 C, b
  31.   {
    . I5 {6 }4 T, M  v
  32.     Error_Handler();( @9 }& S8 }  ^# z  I5 _/ u2 O6 H6 x2 K
  33.   }
    $ v4 c- |& G  F, h
  34. }
复制代码

, @& `( M2 \( F# E: m  J$ n4 }4 G1 g6 R  g
3.2、正点原子提供了系统时钟配置文件(sys.h和sys.c文件)
# F/ c5 N- Y, P* q8 v3 j; l" v
4 C6 p- L" \8 N' O
860ec14f7aac48a7beb6c13b6769d834.png $ s; \( j5 |( [7 g/ C3 J2 O
4 {8 F; @) I6 ?. C
在配置时钟的时候可以查看相应芯片的数据手册) p0 q# z, m. c; O- v3 T5 e
( c, M, x& h' U* h$ Q0 w
0de2099e5005471891c4776542323b64.png 2 D9 w! E8 E( U
  T8 P) E/ D7 d& Z+ E
————————————————2 j) n2 J, ]8 g6 v5 O$ i" o  a' N& m
版权声明:追逐者-桥 如有侵权请联系删除8 S1 O  ]) ]3 G( B' `  C
$ }7 P: q$ c; D/ o& K
3 X4 ~2 K) i. x* f# X: ]1 W3 j6 y
收藏 评论0 发布时间:2023-3-9 14:18

举报

0个回答
关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版