历史上的今天

今天是:2024年09月21日(星期六)

2019年09月21日 | STM32的时钟系统RCC详细整理

发布者:心怀感恩 来源: eefocus关键字:STM32  时钟系统  RCC 手机看文章 扫描二维码
随时随地手机看文章

一、综述:

1、时钟源


在 STM32 中,一共有 5 个时钟源,分别是 HSI 、 HSE 、 LSI 、 LSE 、 PLL 。


 ①HSI 是高速内部时钟, RC 振荡器,频率为 8MHz ;


 ②HSE 是高速外部时钟,可接石英 / 陶瓷谐振器,或者接外部时钟源,频率范围是 4MHz – 16MHz ;


 ③LSI 是低速内部时钟, RC 振荡器,频率为 40KHz ;


 ④LSE 是低速外部时钟,接频率为 32.768KHz 的石英晶体;


 ⑤PLL 为锁相环倍频输出,严格的来说并不算一个独立的时钟源, PLL 的输入可以接 HSI/2 、 HSE 或者 HSE/2 。PLL倍频可选择为 2 – 16 倍,但是其输出频率最大不得超过 72MHz 。


其中, 40kHz 的 LSI 供独立看门狗 IWDG 使用,另外它还可以被选择为实时时钟 RTC 的时钟源。另外,实时时钟RTC 的时钟源还可以选择 LSE ,或者是 HSE 的 128 分频。


STM32 中有一个全速功能的 USB 模块,其串行接口引擎需要一个频率为 48MHz 的时钟源。该时钟源只能从 PLL 端获取,可以选择为 1.5 分频或者 1 分频,也就是,当需使用到 USB 模块时, PLL 必须使能,并且时钟配置为 48MHz或 72MHz 。


另外 STM32 还可以选择一个时钟信号输出到 MCO 脚 (PA.8) 上,可以选择为 PLL 输出的 2 分频、 HSI 、 HSE或者系统时钟。


系统时钟 SYSCLK ,它是提供 STM32 中绝大部分部件工作的时钟源。系统时钟可以选择为 PLL 输出、 HSI 、HSE 。系系统时钟最大频率为 72MHz ,它通过 AHB 分频器分频后送给各个模块使用, AHB 分频器可以选择 1 、 2、 4 、 8 、 16 、 64 、 128 、 256 、 512 分频,AHB分频器输出的时钟送给 5 大模块使用:


       ①送给 AHB 总线、内核、内存和 DMA 使用的 HCLK 时钟;


       ②通过 8 分频后送给 Cortex 的系统定时器时钟STCLK;


       ③直接送给 Cortex 的空闲运行时钟 FCLK ;


       ④送给 APB1 分频器。 APB1 分频器可以选择 1 、 2 、 4 、 8 、 16 分频,其输出一路供 APB1 外设使用(PCLK1 ,最大频率 36MHz ),另一路送给定时器 (Timer)2 、 3 、 4 倍频器使用。该倍频器根据PCLK1的分频值自动选择 1 或者 2 倍频,时钟输出供定时器 2 、 3 、 4 使用。


       ⑤送给 APB2 分频器。 APB2 分频器可以选择 1 、 2 、 4 、 8 、 16 分频,其输出一路供 APB2 外设使用(PCLK2 ,最大频率 72MHz ),另外一路送给定时器 (Timer)1 倍频使用。该倍频器根据PCLK2的分频值自动选择1 或 2 倍频,时钟输出供定时器 1 使用。另外 APB2 分频器还有一路输出供 ADC 分频器使用,分频后送给 ADC 模块使用。 ADC 分频器可选择为 2 、 4 、 6 、 8 分频。


需要注意的是定时器的倍频器,当 APB 的分频为 1 时,它的倍频值为 1 ,否则它的倍频值就为 2 。

2、APB1和APB2连接的模块


①连接在 APB1( 低速外设 ) 上的设备有:电源接口、备份接口、 CAN 、 USB 、 I2C1 、 I2C2 、 UART2 、UART3 、 SPI2 、窗口看门狗、 Timer2 、 Timer3 、 Timer4 。 注意 USB 模块虽然需要一个单独的 48MHz 的时钟信号,但是它应该不是供 USB 模块工作的时钟,而只是提供给串行接口引擎 (SIE) 使用的时钟。 USB 模块的工作时钟应该是由 APB1 提供的。


②连接在 APB2 (高速外设)上的设备有: UART1 、 SPI1 、 Timer1 、 ADC1 、 ADC2 、 GPIOx(PA~PE) 、第二功能 IO 口。


二、寄存器介绍:


typedef struct


{


  __IO uint32_t CR;


  __IO uint32_t CFGR;


  __IO uint32_t CIR;


  __IO uint32_t APB2RSTR;


  __IO uint32_t APB1RSTR;


  __IO uint32_t AHBENR;


  __IO uint32_t APB2ENR;


  __IO uint32_t APB1ENR;


  __IO uint32_t BDCR;


  __IO uint32_t CSR;


#ifdef STM32F10X_CL 


  __IO uint32_t AHBRSTR;


  __IO uint32_t CFGR2;


#endif /* STM32F10X_CL */


#if defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL)  


  uint32_t RESERVED0;


  __IO uint32_t CFGR2;


#endif /* STM32F10X_LD_VL || STM32F10X_MD_VL || STM32F10X_HD_VL */


} RCC_TypeDef;


1、时钟控制寄存器(RCC_CR):(复位值为0x0000 xx83,内部低速时钟使能和就绪,内部时钟校准)


主要功能:内外部高速时钟的使能和就绪标志(含内部高速时钟校准调整),外部高速时钟旁路,时钟安全系统CSS使能,PLL使能和PLL就绪标志。


2、时钟配置寄存器(RCC_CFGR):(复位值为0x0000 0000)


主要功能:系统时钟源切换及状态,AHB、APB1、APB2、ADC、USB预分频,PLL输入时钟源选择及HSE输入PLL分频选择,PLL倍频系数,MCO(PA8)引脚微控制器时钟输出。


3、时钟中断寄存器 (RCC_CIR):(复位值: 0x0000 0000)


主要功能:LSI、LSE、HIS、HSE、PLL就绪中断标志,HSE时钟失效导致时钟安全系统中断标志,LSI、LSE、HIS、HSE、PLL就绪中断使能,清除LSI、LSE、HIS、HSE、PLL就绪中断,清除时钟安全系统中断。


4、APB2外设复位寄存器 (RCC_APB2RSTR):(复位值: 0x0000 0000)


主要功能:AFIO、IOPA、IOPB、IOPC、IOPD、IOPE、IOPF、IOPG、ADC1、ADC2、TIM1、SPI1、TIM8、USART1、ADC3复位。


5、APB1外设复位寄存器 (RCC_APB1RSTR) :(复位值: 0x0000 0000)


主要功能:TIM2、TIM3、TIM4、TIM5、TIM6、TIM7、WWDG、SPI2、SPI3、USART2、USART3、USART4、USART5、I2C1、I2C2、USB、CAN、BKP、PWR、DAC复位。


6、AHB外设时钟使能寄存器 (RCC_AHBENR) :(复位值: 0x0000 0014睡眠模式时SRAM、闪存接口电路时钟开启)


主要功能:DMA1、DMA2、SRAM、FLITF、CRC、FSMC、SDIO时钟使能。


7、APB2外设时钟使能寄存器(RCC_APB2ENR) :(复位值: 0x0000 0000)


主要功能:AFIO、IOPA、IOPB、IOPC、IOPD、IOPE、IOPF、IOPG、ADC1、ADC2、TIM1、SPI1、TIM8、USART1、ADC3时钟使能。


8、APB1外设时钟使能寄存器(RCC_APB1ENR) :(复位值: 0x0000 0000)


主要功能:TIM2、TIM3、TIM4、TIM5、TIM6、TIM7、WWDG、SPI2、SPI3、USART2、USART3、USART4、USART5、I2C1、I2C2、USB、CAN、BKP、PWR、DAC时钟使能。


9、备份域控制寄存器 (RCC_BDCR) :(复位值: 0x0000 0000)


主要功能:外部低速振荡器使能和就绪标志及旁路、RTC时钟源选择和时钟使能、备份域软件复位。


10、控制/状态寄存器 (RCC_CSR) :(复位值: 0x0C00 0000 NRST引脚复位标志、上电/掉电复位标志)


主要功能:内部低速振荡器就绪、清除复位标志、NRST引脚复位标志、上电/掉电复位标志、软件复位标志、独立看门狗复位标志、窗口看门狗复位标志、低功耗复位标志。


三、初始化设置


采用8MHz 外部HSE 时钟,在 MDK 编译平台中,程序的时钟设置参数流程如下:


    将 RCC 寄存器重新设置为默认值:RCC_DeInit();


    打开外部高速时钟晶振 HSE :    RCC_HSEConfig(RCC_HSE_ON);


    等待外部高速时钟晶振工作:       HSEStartUpStatus = RCC_WaitForHSEStartUp();


    设置 AHB 时钟 (HCLK) :          RCC_HCLKConfig(RCC_SYSCLK_Div1);


        设置APB 2时钟 (APB2) :    RCC_PCLK2Config(RCC_HCLK_Div1);


        设置APB1 时钟 (APB1) :    RCC_PCLK1Config(RCC_HCLK_Div2);


        设置 PLL :       RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);


    打开 PLL :                                  RCC_PLLCmd(ENABLE);


    等待 PLL 工作:    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);


设置系统时钟:    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);


判断 PLL 是否是系统时钟:        while(RCC_GetSYSCLKSource() != 0x08);


1、使用库函数进行时钟系统初始化配置


void RCC_config()//如果外部晶振为8M,PLLCLK=SYSCLK=72M,HCLK=72M,//P2CLK=72M,P1CLK=36M,ADCCLK=36M,USBCLK=48M,TIMCLK=72M


{


       ErrorStatus HSEStartUpStatus; // 定义错误状态变量


       RCC_DeInit();//将RCC寄存器重新设置为默认值


       RCC_HSEConfig(RCC_HSE_ON); //打开外部高速时钟晶振


       HSEStartUpStatus = RCC_WaitForHSEStartUp();// 等待外部高速时钟晶振工作


       if(HSEStartUpStatus == SUCCESS)


       {


       RCC_HCLKConfig(RCC_SYSCLK_Div1);//设置AHB不分频,HCLK=SYSCLK


       RCC_PCLK2Config(RCC_HCLK_Div1);//设置APB2不分频,P2CLK=HCLK


       RCC_PCLK1Config(RCC_HCLK_Div2); //设置APB1 为2分频,P1CLK=HCLK/2


       FLASH_SetLatency(FLASH_Latency_2);//设置FLASH代码延时


       FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);//使能预取指缓存


       RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);//设置PLL时钟源,


//外部时钟不分频,为HSE的9倍频8MHz * 9 = 72MHz


       RCC_PLLCmd(ENABLE);//使能PLL


       while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);//等待PLL准备就绪


       RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);//设置PLL为系统时钟源


       while(RCC_GetSYSCLKSource() != 0x08);//判断PLL是否是系统时钟


       }


            /*RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOD, ENABLE); // 打开 PB 和 PD 用于点亮 LED 灯*/


}


2、使用寄存器进行RCC时钟初始化配置


void RCC_init(u8 PLL)//输入PLL的倍频值2—16倍频


//HCLK=PLLCLK=SYSCLK=P2CLK=P1CLK*2=ADCCLK*2=TIMCLK=USBCLK*2/3


{


       unsigned char temp=0;  


       //RCC_DeInit();              //将RCC寄存器重新设置为默认值


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


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


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


       PLL-=2;//抵消2个单位


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


       RCC->CFGR|=1<<16;     //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;


       }   


}


四、相关库函数解析


1、库中所涉及到的结构体


typedef struct

 

{

 

  uint32_t SYSCLK_Frequency;  /*!< returns SYSCLK clock frequency expressed in Hz */

 

  uint32_t HCLK_Frequency;    /*!< returns HCLK clock frequency expressed in Hz */

 

  uint32_t PCLK1_Frequency;   /*!< returns PCLK1 clock frequency expressed in Hz */

 

  uint32_t PCLK2_Frequency;   /*!< returns PCLK2 clock frequency expressed in Hz */

 

  uint32_t ADCCLK_Frequency; /*!< returns ADCCLK clock frequency expressed in Hz */

 

}RCC_ClocksTypeDef;


2、库函数解析


void RCC_DeInit(void);//将外设RCC寄存器设为缺省值;(除RCC_BDCR和RCC_CSR)


void RCC_HSEConfig(uint32_t RCC_HSE);//设置外部高速晶振(HSE);


//输入:RCC_HSE_OFF,RCC_HSE_ON,RCC_HSE_Bypass(HSE旁路)


ErrorStatus RCC_WaitForHSEStartUp(void);//等待HSE起振;


//返回值:SUCCESS,HSE晶振稳定且就绪;ERROR,HSE晶振未就绪


void RCC_AdjustHSICalibrationValue(uint8_t HSICalibrationValue);//调整内部高速晶振(HSI)校准值


//输入:校准补偿值(该参数取值必须在0到0x1F之间)


void RCC_HSICmd(FunctionalState NewState);//使能或者失能内部高速晶振(HSI)


//输入:ENABLE或者DISABLE(如果HSI被用于系统时钟,或者FLASH编写操作进行中,那么它不能被停振)


void RCC_PLLConfig(uint32_t RCC_PLLSource, uint32_t RCC_PLLMul);//设置PLL时钟源及倍频系数


//输入:RCC_PLLSource_HSI_Div2,RCC_PLLSource_HSE_Div1,RCC_PLLSource_HSE_Div2


//输入:RCC_PLLMul_2到RCC_PLLMul_16


void RCC_PLLCmd(FunctionalState NewState);// 使能或者失能PLL


//输入:ENABLE或者DISABLE


#if defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || defined (STM32F10X_HD_VL) || defined (STM32F10X_CL)


 void RCC_PREDIV1Config(uint32_t RCC_PREDIV1_Source, uint32_t RCC_PREDIV1_Div);//


#endif


#ifdef  STM32F10X_CL


 void RCC_PREDIV2Config(uint32_t RCC_PREDIV2_Div);//


 void RCC_PLL2Config(uint32_t RCC_PLL2Mul);//


 void RCC_PLL2Cmd(FunctionalState NewState);//


 void RCC_PLL3Config(uint32_t RCC_PLL3Mul);//


 void RCC_PLL3Cmd(FunctionalState NewState);//


#endif /* STM32F10X_CL */


void RCC_SYSCLKConfig(uint32_t RCC_SYSCLKSource);//设置系统时钟(SYSCLK)源


// RCC_SYSCLKSource_HSI,RCC_SYSCLKSource_HSE,RCC_SYSCLKSource_PLLCLK


uint8_t RCC_GetSYSCLKSource(void);// 返回用作系统时钟的时钟源


//返回值:0x00 HSI作为系统时钟,0x04 HSE作为系统时钟,0x08 PLL作为系统时钟


void RCC_HCLKConfig(uint32_t RCC_SYSCLK);//设置AHB时钟(HCLK)


//输入:RCC_SYSCLK_Div1,RCC_SYSCLK_Div2,RCC_SYSCLK_Div4,RCC_SYSCLK_Div8,RCC_SYSCLK_Div16,


//RCC_SYSCLK_Div32,RCC_SYSCLK_Div64,RCC_SYSCLK_Div128,RCC_SYSCLK_Div256,RCC_SYSCLK_Div512


void RCC_PCLK1Config(uint32_t RCC_HCLK);// 设置低速AHB时钟(PCLK1)

[1] [2] [3] [4]
关键字:STM32  时钟系统  RCC 引用地址:STM32的时钟系统RCC详细整理

上一篇:IAR EW6.30版本下建立STM32工程(芯片型号STM32F105VC)
下一篇:stm32上电自启动后运行不正常的故障排查分析

推荐阅读

第二十届中国国际工业博览会于9月19日在国家会展中心(上海)盛大启幕。开展第一天就一如既往地吸引了来自各界的关注。 此次博览会以“创新、智能、绿色”为主题,设置8大专业展,其中,工业自动化展(IAS2018)作为工业博览会最受瞩目的专业展之一,众多企业集中展示创新产品、智能制造的核心技术和前端产品,为专业用户提供更有针对性和高效的产品体验。...
过去几十年内,模拟人体皮肤宽量程感官功能和强拉伸性能的柔性电子器件层出不穷。这类被称为“人造皮肤”的器件可以感知温度、压力、应力、震动和生物标记物并将其转化为可量化的电信号,为医疗保健、可穿戴设备和软体机器人等领域提供了新的机遇。复旦大学武培怡教授在Materials Horizons上发表了一种利用3D打印技术制造的人工皮肤,通过刺激响应性水凝...
MSP430G2553单片机称之为混合信号处理器,是由于其针对实际应用需求,将多个不同功能的模拟电路、数字电路模块和微处理器集成在一个芯片上,以提供“单片机”解决方案。该系列单片机多应用于需要电池供电的便携式仪器仪表中。
英飞凌科技股份公司日前宣布,其位于奥地利菲拉赫的300毫米薄晶圆功率半导体芯片工厂正式启动运营。这座以“面向未来”为座右铭的芯片工厂,总投资额为16亿欧元,是欧洲微电子领域同类中最大规模的项目之一,也是现代化程度最高的半导体器件工厂之一。欧盟委员Thierry Breton、奥地利总理Sebastian Kurz、英飞凌科技股份公司首席执行官Reinhard Ploss博...

史海拾趣

问答坊 | AI 解惑

一个关于Q格式的问题

我想请问一下大家,怎么样才能实现在C语言中完成Q格式的转化?…

查看全部问答∨

C8051单片机和Q2BYG403CM驱动器如何接线和控制?

如果采用单脉冲控制(脉冲+方向),则方向信号DR+,DR-和脉冲信号PU+,PU-如何和51单片机接线,接到那个口?同时A+,A-和B+,B-如何接到电机?为什么细分时(驱动器说明书)SW对应MS 时,MS有两个值? 本人是单片机初学者,希望得到各位的帮助,在此 ...…

查看全部问答∨

【晒经典】电焊机节电保护器原理图

本帖最后由 dontium 于 2015-1-23 13:28 编辑 AC380V电压经电容降压,桥式整流后给直流电路供电。火线L2经Q2,T2给交流负载供电(负载图中没画),T2检测负载电流,到设定值时,Q1导通,直流电源被拉低,K1释放,交流接触器K2吸合。T1也是检测电流 ...…

查看全部问答∨

vxworks中的解压缩

请问各位大侠,针对不同架构的cpu的vxworks源代码中,是否是采用相同的inflate/deflate解压缩代码啊? 例如,能否调用sparc架构的vxworks代码的inflate代码,解压缩用mips架构的vxworks代码中deflate压缩的文件呢? [ 本帖最后由 茵子 于 2011-9- ...…

查看全部问答∨

自己整理的ADI的dsp学习资料,从今天开始连载大家一起学习

学习ADIdsp已经有一段时间了,把学习的一些心得整理了一下,陆陆续续发上来,大家一起学习进步…

查看全部问答∨

关于硬件I2C的,用的是I2C1

/*---------------------------------------------------------------------------------------------------------*********************************************************************************************************** 文件名称 :&nbs ...…

查看全部问答∨

【项目外包】飞思卡尔32位Power Pc架构MPC5XXX芯片驱动开发

飞思卡尔32位Power Pc架构MPC5XXX芯片驱动开发 项目预算:¥ 1,~100,000 开发周期: 60 天 项目分类: 嵌入式 竞标要求: 项目标签: ...…

查看全部问答∨

学习Sitara AM335x之思路篇

本人专业是电路与系统,结合自己学习ARM9的情况,我想谈谈学习这款芯片的思路,希望大家一起讨论一起研究。我觉得最初应该先把Sitara当单片机使更合适些,因为电子相关的专业的同学大部分还是希望往驱动固件开发方向发展(这个方向工资也不错,将来 ...…

查看全部问答∨

关于用VB6.0编写软件来实现无线遥控atmega128单片机的问题。

各位朋友,大家好! 我用的是ATmega128最小系统板来控制小车的四个电机转动,采用无线遥控模块,模块型号是XL03-232AP2-1收发模块(睿迪无线产的),单片机作为接收端,程序如下: #include<avr/io.h> #include<avr/interrupt.h> #defi ...…

查看全部问答∨
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多每日新闻

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved