您的位置 首页 新品

STM32F103x RCC寄存器装备

rccresetandclockcontrol复位及时钟控制主要是设置时钟树中的内容,如下图所示:具体在RCC_Configuration函数中的体现。第一步:系统时钟…

rccresetandclockcontrol 复位及时钟操控

主要是设置时钟树中的内容,如下图所示:

详细在RCC_Configuration函数中的表现。

第一步:体系时钟挑选哪个,HSE、HSI仍是PLLCLK。


RCC_HSEConfig(RCC_HSE_ON); //运用HSE


假如HSE时钟现已安稳,硬件会将RCC_CR的HSERDY方位1。

第二步:判别HSE时钟是否安稳


if(RCC_WaitForHSEStartUp()==SUCCESS)


第三步:使能FLASH的预取址缓冲区,并设置FLASH的等候状况。(详细功用见FLASH部分)


/*EnablePrefetchBuffer*/

FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);

/*Flash2waitstate*/

FLASH_SetLatency(FLASH_Latency_2);


第四步:设置AHB预分频系数。预分频系数可所以1、2、4、8、16、32、64、128、256


/*HCLK=SYSCLK*/

RCC_HCLKConfig(RCC_SYSCLK_Div1);//没分频


第五步:设置APB2的预分频系数,来确认PCLK2频率。预分频系数可所以1、2、4、8、16


/*PCLK2=HCLK*/

RCC_PCLK2Config(RCC_HCLK_Div1);//没分频


第六步:设置APB1的预分频系数,来确认PCLK1频率。预分频系数可所以1、2、4、8、16


/*PCLK1=HCLK/2*/

RCC_PCLK1Config(RCC_HCLK_Div2);//2分频


第七步:设置PLL的时钟源,以及PLL的倍频系数,来确认PLLCLK频率。


/*PLLCLK=8MHz*9=72MHz*/

RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);


第八步:使能PLL。将RCC_CR的PLLON方位1。


/*EnablePLL*/

RCC_PLLCmd(ENABLE);


假如PLL确定后,硬件会将RCC_CR的PLLRDY方位1。

第九步:等候PLL确定。


/*WaittillPLLisready*/

while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET){}


第十步:挑选PLL作为SYSCLK(体系时钟源)



/*SelectPLLassystemclocksource*/

RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);


第十一步:将程序中用到的外设时钟翻开,一致都放在此处。

例如:将GPIO外设时钟翻开。


/* Enable GPIOC clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);


RCC_Configuration函数详细代码如下:


/*******************************************************************************
* Function Name : RCC_Configuration
* Description : Configures the different system clocks.
* Input : None

* Return : None
*******************************************************************************/
void RCC_Configuration(void)
{
ErrorStatus HSEStartUpStatus;

/* 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);

/* Flash 2 wait state */
FLASH_SetLatency(FLASH_Latency_2);

/* HCLK = SYSCLK */
RCC_HCLKConfig(RCC_SYSCLK_Div1);

/* PCLK2 = HCLK */
RCC_PCLK2Config(RCC_HCLK_Div1);

/* PCLK1 = HCLK/2 */
RCC_PCLK1Config(RCC_HCLK_Div2);

/* PLLCLK = 8MHz * 9 = 72 MHz */
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);

/* Enable PLL */
RCC_PLLCmd(ENABLE);

/* Wait till PLL is ready */
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) {}

/* Select PLL as system clock source */
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);

/* Wait till PLL is used as system clock source */
while(RCC_GetSYSCLKSource() != 0x08) {}

/* Enable GPIOC clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE);
}
}


声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/xinpin/275228.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部