STM32 时钟

STM32有三种不同的时钟源可被用来驱动系统时钟(SYSCLK): 

 1HSI振荡器时钟(内部时钟)

2HSE振荡器时钟 (外部时钟,即晶振所提供)

 3PLL时钟(锁相环时钟)

 这些设备有以下2种二级时钟源: 

 (1)40kHz低速内部RC,可以用于驱动独立看门狗和通过程序选择驱动RTC。RTC用于从停机/待机模式下自动唤醒系统。 

 (232.768kHz低速外部晶体也可用来通过程序选择驱动RTC(RTCCLK)。 

 当不被使用时,任一个时钟源都可被独立地启动或关闭,由此优化系统功耗。

 

 STM32PLL时钟配置函数:

 void Stm32_Clock_Init(u8 PLL)

 {

  unsigned char temp=0; //当前系统时钟状态标志  

  MYRCC_DeInit();   //复位并配置向量表

  RCC->CR|=0x00010000;  //外部高速时钟使能HSEON

  while(!(RCC->CR>>17));//等待外部时钟就绪

  RCC->CFGR=0X00000400; //APB1=DIV2;APB2=DIV1;AHB=DIV1;

  PLL-=2;//抵消2个单位  //这里PLL减去2是因为倍频系数从2开始,但倍频寄存器值从 0000开始,即如果是9倍频,则倍频寄存器应写0111。

  RCC->CFGR|=PLL<<18;   //设置PLL值 2~16

  RCC->CFGR|=1<<16;   //由软件置’1’或清’0’来选择PLL输入时钟源。该位只有在PLL关闭时才 可以被写入。

  FLASH->ACR|=0x32;   //FLASH 2个延时周期

 

  RCC->CR|=0x01000000;  //PLLON

  while(!(RCC->CR>>25));//等待PLL锁定

  RCC->CFGR|=0x00000002;//PLL作为系统时钟  

  while(temp!=0x02)     //等待PLL作为系统时钟设置成功

  {   

  temp=RCC->CFGR>>2;

  temp&=0x03;

  }    

 }

附:时钟控制寄存器RCC_CR与时钟配置寄存器RCC_CFGR配置表

 

 

 1:常用配置如下

 使用HSE作为PLL的输入源,将PLL的输出配置为72MHZ,然后将PLL作为系统时钟,最后将其他时钟配置为系统时钟的分频输出。

 2:配置过程

 -将所有和时钟相关的寄存器进行复位;

 -启动HSE并等待其稳定;

 -配置HCLK和SYSCLK相等;

 -配置PCLK1为HCLK的2分频;(由参考手册上的时钟树得知PCLK1为低速外设时钟,最大不超过36MHZ,所以,PLL倍频不建议超过72MHZ)

 -配置PCLK2和HCLK相等;(PCLK2为高速外设时钟,最大不超过72MHZ)

 -根据是否使用AD及其输入信号的频率配置ADCLK为PCLK2的若干分频;

 -根据是否使用USB设备接口,配置USB的时钟为48MHZ;

 -配置HSE为PLL的输入,并设置两个分频比使PLL输出72MHZ频率,等待其稳定;

 -将PLL输出作为系统时钟;

 -根据需要来决定是否启用时钟安全系统。

注意:

1.当HSI作为PLL时钟的输入时,最高的系统时钟频率只能达到64MHz。

2.当使用USB功能时,必须同时使用HSE和PLL,CPU的频率必须是48MHz或72MHz。

 3.当需要ADC采样时间为1μs时,APB2必须设置在14MHz、28MHz或56MHz。

 附——STM32时钟树:

 

 引用STM32 datasheet 上的一段话:

系统时钟的选择是在启动时进行,复位时内部8MHZ的RC振荡器被选为默认的CPU时钟,随后可以选择外部的、具失效监控的4-16MHZ时钟;当检测到外部时钟失效时,它将被隔离,系统将自动地切换到内部的RC振荡器,如果使能了中断,软件可以接收到相应的中断。同样,在需要时可以采取对PLL时钟完全的中断管理(如当一个间接使用的外部振荡器失效时)。

多个预分频器用于配置AHB的频率、高速APB(APB2)和低速APB(APB1)区域。AHB和高速APB的最高频率是72MHZ,低速APB的最高频率为36MHZ。

 

你可能感兴趣的:(STM32,初探)