STM32F2XX之RCC配置
一、???????? 系统时钟配置 STM32有多个时钟源,分别是HSI,HSE,LSE,LSI。 HSI振荡器时钟: 系统上电默认时钟,内部振荡器8MHZ,可以直接作为系统时钟或在2分频后作为PLL的输入。时钟频率精度较差。 HSE振荡器时钟外部: 提供非常精确的主时钟,STM32F1系列的板上为8MHZ,STM32F2系列的板上为25MHZ晶振。经过PLL倍频:作为系统时钟。 PLL时钟源输入可以是HSI时钟的二分之一,或者HSE时钟。 LSE时钟: LSE晶体是一个32.867k的低速外部晶体。提供实时时钟。一般专门用于RTC,等到RTC模块时再使用。 LSI时钟(Internal内部): LSI的RC担当一个低功耗时钟源的角色,它可以在停机和待机模式下保存运行。为独立看门狗和自动唤醒单元提供时钟。LSI时钟频率大约40KHZ。一般用于IWDGCLK。 通常的时钟选择为HSE配合PLL使其工作在72MHZ(STM32F1系列)或者120MHZ(STM32F2系列)。 STM32F1xx系列 STM32F2XX系列 RCC_DeInit()同SystemInit()的区别仅仅在于SystemInit()多一个SetSysClock()。SystemInit()包含了整个内部时钟到外部时钟的配置,但配置的频率不可调,如需调整频率,可以自己用RCC_DeInit()再配合其他操作进行。 配置时钟流程: 1.将RCC寄存器重新设置为默认值?????????RCC_DeInit; 2.打开外部高速时钟晶振HSE?????????????????RCC_HSEConfig(RCC_HSE_ON); 3.等待外部高速时钟晶振工作??????????HSEStartUpStatus =RCC_WaitForHSEStartUp(); 4.设置AHB时钟??????????????????????????????RCC_HCLKConfig; 5.设置高速APB2时钟?????????????????????RCC_PCLK2Config; 6.设置低速速APB1时钟??????????????????RCC_PCLK1Config 7.设置PLL???????????????????????????????????????RCC_PLLConfig; 8.打开PLL???????????????????????????????????????RCC_PLLCmd(ENABLE); 9.等待PLL工作?????????????????while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); 10.设置系统时钟??????????????????????????????RCC_SYSCLKConfig; 11.判断是否PLL是系统时钟????????????while(RCC_GetSYSCLKSource() != 0x08); 12.打开要使用的外设时钟??RCC_APB2PeriphClockCmd()/RCC_APB1PeriphClockCmd(); /******************************************************************************* * Function Name?: RCC_Configuration * Description???: Configures the different system clocks. * Input?????????: None * Output????????: None * Return????????: None *******************************************************************************/ void RCC_Configuration(void) { ? /* RCC system reset(for debug purpose) */ ? RCC_DeInit(); ? ? /* Enable HSE */ ? RCC_HSEConfig(RCC_HSE_ON); ? ??/* Wait till HSE is ready */ ? HSEStartUpStatus = RCC_WaitForHSEStartUp(); ? ? if(HSEStartUpStatus == SUCCESS) ? { ??? /* Enable Prefetch Buffer */ ??? FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); ??? ??? /* HCLK = SYSCLK */ ??? RCC_HCLKConfig(RCC_SYSCLK_Div1); ? ??? /* PCLK2 = HCLK */ ??? RCC_PCLK2Config(RCC_HCLK_Div1); ? ??? /* PCLK1 = HCLK */ ??? RCC_PCLK1Config(RCC_HCLK_Div1); ? ??? /* Select HSE as system clock source */ ??? RCC_SYSCLKConfig(RCC_SYSCLKSource_HSE); ? ??? /* Wait till HSE is used as system clock source */ ??? while(RCC_GetSYSCLKSource() != 0x04) ??? { ??? } ? } XXXXXXXX;??? //分别为其他外设的时钟配置。 XXXXXXXX; ? XXXXXXXX; } ? ? ? 二、???????? 关于PLL设置 PLL的设置主要通过函数:void RCC_PLLConfig(uint32_t RCC_PLLSource,uint32_t PLLM,uint32_t PLLN,uint32_t PLLP,uint32_t PLLQ,uint32_t PLLR)来实现。 主要讲一下PLL值的设置与各部分时钟的关系。函数中涉及到6个量的设置,第一个为内部时钟或者外部时钟选择,后面几个为PLL值的设置。 l? RCC_PLLSource选择: RCC_PLLSource_HIS:HIS内部时钟选定,频率为16MHZ RCC_PLLSource_HSE:HSE外部时钟选定,频率可自选,4MHZ-26MHZ之间,系统默认25MHZ,如需改变,则对stm32f2xx.h中第70行的 #define HSE_VALUE????((uint32_t)25000000) /*!< Value of the External oscillator in Hz */ 进行修改,改成外部晶振的值。 l? 通过选择PLLM和PLLN,来计算得到PLLVCO,计算公式如下: PLLVCO = (HSE_VALUE / PLL_M) * PLL_N。 PLL_M可取0-63,PLL_N可取192-432。 l? 通过选择PLLP来选择分频数,以得到系统时钟。计算公式如下: SYSCLK = PLLVCO / PLL_P,切记不要超过120MHZ最大频率。 PLLP可选范围为2,4,6,8。 l? 通过选择PLLQ来OTGFS,SDIO和RNG的时钟。计算公式如下: Clock =? PLLVCO / PLLQ,不能超过48MHZ。 PLL_Q可取4-15。 l? 通过选择PLLR来决定I2S的时钟。计算公式如下: I2SCLK =? PLLVCO / PLLR。 PLL_R可取2-7。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |