【STM32学习笔记2】RCC时钟系统

前言

本系列文章统一围绕STM32F103C8T6最小系统开发板进行记录,如涉及其他开发板将会特别说明。

STM32时钟的概念

时钟对于STM32而言是驱动源,相当于人类的心脏。有了时钟,STM32才能运行,并给片上的所有外设模块提供时钟使其正常工作。

STM32中系统时钟为什么有这么多的时钟源?

  • 提供STM32系统内核、各种总线和外设所需要的工作频率。
  • 增加抗电磁干扰能力,提高稳定性。
  • 考虑掉电情况(外部高/低速时钟无法正常供电时,内部高/低速时钟可以提供时钟源)。

时钟源

以stm32f1系列为例:

  1. 外部高速时钟(HSE)

    • 来源:可接石英 / 陶瓷谐振器,或者接外部时钟源。
    • 频率范围是 4MHz – 16MHz。
    • 可以直接作为系统时钟或PLL输入。
  2. 内部高速时钟(HSI)

    • 来源:内部RC振荡器。
    • 频率为8MHz(用此时钟源,系统时钟SYSCLK的最大频率不超过64MHz,8/2*16 = 64MHz)。
    • 可以直接作为系统时钟或PLL输入。
  3. 外部低速时钟(LSE)

    • 来源:外接石英晶体。
    • 频率为 32.768KHz。
    • 主要是RTC的时钟源。
  4. 内部低速时钟(LSI)

    • 来源:内部RC 振荡器。
    • 频率为 40KHz左右(30K-60KHz)。
    • 供独立看门狗和自动唤醒单元使用。
  5. 锁相环时钟(PLL):锁相环倍频输出,可作为系统的时钟源,严格的来说并不算一个独立的时钟源。

    • 来源:HSI/2 、 HSE 或者 HSE/2 。
    • PLL倍频因子:2 – 16 倍。
    • 输出频率最大不得超过 72MHz。
  6. 系统时钟源(SYSTICK):

    • 最大频率为72MHz。
    • 来源:PLL倍频输出、HSI或者HSE。
    • 输出:AHB分频器。
RCC时钟树
  1. AHB总线时钟(HCLK):将系统时钟频率进行分频并提供给各模块使用。
    • 分频因子:1、2、4、8、16、64、128、256、512。
    • 主要输出:
      • AHB总线、内核、内存和DMA使用的HCLK时钟。
      • 通过8分频后送给Cortex的系统定时器时钟。
      • Cortex的自由运行时钟FCLK。
      • APB1预分频器。
      • APB2预分频器 。
  2. APB1总线时钟(PCLK1):低速总线时钟,最大为36MHz。
    • 来源:由AHB分频而得。
    • 分频因子:1、2、4、8、16。
    • 输出:APB1外设、通用定时器2~7。
  3. APB2总线时钟(PCLK2):高速总线时钟,最大为72MHz。
    • 来源:由AHB分频而得。
    • 分频因子:1、2、4、8、16。
    • 输出:APB2外设、高级定时器1和定时器8。
系统总线架构.png

RCC寄存器

  1. RCC_CR 时钟控制寄存器

    • 内外部高速时钟的使能和就绪标志(含内部高速时钟校准调整)。
    • 外部高速时钟旁路。
    • 时钟安全系统CSS使能。
    • PLL使能和PLL就绪标志。
  2. RCC_CFGR 时钟配置寄存器

    • 系统时钟源切换及状态。
    • AHB、APB1、APB2、ADC、USB预分频选择。
    • PLL输入时钟源选择及HSE输入PLL分频选择,PLL倍频系数选择。
    • MCO(PA8)引脚微控制器时钟输出。
  3. RCC_APBxRSTR 外设复位寄存器

    • LSI、LSE、HIS、HSE、PLL就绪中断标志。
    • HSE时钟失效导致时钟安全系统中断标志。
    • LSI、LSE、HIS、HSE、PLL就绪中断使能。
    • 清除LSI、LSE、HIS、HSE、PLL就绪中断。
    • 清除时钟安全系统中断。
  4. RCC_AHBENR/APBxENR外设时钟使能寄存器

    • 主要功能:使能AHB、APB1、APB2总线下的各外设
  5. RCC_APBxRSTR 外设复位寄存器

    • 主要功能:APB1、APB2总线下的各外设复位

系统时钟的配置

以stm32f1系列为例:官方提供的启动文件startup_stm32f10x_hd.s中,在执行main函数前会调用system_stm32f10x.c文件下的SystemInit函数对系统时钟进行配置。

在SystemInit函数下的SetSysClock函数,会对系统时钟频率、HCLK、PCLK等进行具体配置。

/**
  * @brief  Configures the System clock frequency, HCLK, PCLK2 and PCLK1 prescalers.
  * @param  None
  * @retval None
  */
static void SetSysClock(void)
{
#ifdef SYSCLK_FREQ_HSE
  SetSysClockToHSE();
#elif defined SYSCLK_FREQ_24MHz
  SetSysClockTo24();
#elif defined SYSCLK_FREQ_36MHz
  SetSysClockTo36();
#elif defined SYSCLK_FREQ_48MHz
  SetSysClockTo48();
#elif defined SYSCLK_FREQ_56MHz
  SetSysClockTo56();  
#elif defined SYSCLK_FREQ_72MHz
  SetSysClockTo72();
#endif

设置系统时钟频率为72MHz的基本流程:

  1. 使能HSE时钟并等待完成。
  /* Enable HSE */    
  RCC->CR |= ((uint32_t)RCC_CR_HSEON);
 
  /* Wait till HSE is ready and if Time out is reached exit */
  do
  {
    HSEStatus = RCC->CR & RCC_CR_HSERDY;
    StartUpCounter++;  
  } while((HSEStatus == 0) && (StartUpCounter != HSE_STARTUP_TIMEOUT));

  if ((RCC->CR & RCC_CR_HSERDY) != RESET)
  {
    HSEStatus = (uint32_t)0x01;
  }
  else
  {
    HSEStatus = (uint32_t)0x00;
  } 
  1. 设置HCLK、PCLK1、PCLK2频率。
  /* HCLK = SYSCLK */
  RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;
  /* PCLK2 = HCLK */
  RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE2_DIV1;
  /* PCLK1 = HCLK */
  RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE1_DIV2;
  1. 使能PLL锁相环时钟并设置倍频因子为9(9*8MHz = 72MHz),使能并选择其为系统的时钟源。
  /*  PLL configuration: PLLCLK = HSE * 9 = 72 MHz */
  RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_PLLSRC | RCC_CFGR_PLLXTPRE |
                                        RCC_CFGR_PLLMULL));
  RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLSRC_HSE | RCC_CFGR_PLLMULL9);

  /* Enable PLL */
  RCC->CR |= RCC_CR_PLLON;

  /* Wait till PLL is ready */
  while((RCC->CR & RCC_CR_PLLRDY) == 0)
  {
  }
    
  /* Select PLL as system clock source */
  RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
  RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;    

  /* Wait till PLL is used as system clock source */
  while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)0x08)
  {
  }

至此,成功将系统时钟频率设置为72MHz,其中PCLK1为36MHz,PCLK2为72MHz。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,794评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,050评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,587评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,861评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,901评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,898评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,832评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,617评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,077评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,349评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,483评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,199评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,824评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,442评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,632评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,474评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,393评论 2 352

推荐阅读更多精彩内容