STM32之RCC
STM32有多個(gè)時(shí)鐘源,分別是
HSI:上電默認(rèn)啟動(dòng),因精度不高所以先不采用,以后如果需要再使用
HSE:外部高速時(shí)鐘,系統(tǒng)時(shí)鐘一般采用它,經(jīng)過PLL倍頻作為系統(tǒng)同時(shí)鐘
LSE:外部低速時(shí)鐘,一般專門用于RTC,等到RTC模塊時(shí)再使用
LSI:內(nèi)部低速時(shí)鐘,精度不高,一般用于IWDGCLK
時(shí)鐘系統(tǒng)框圖如下:
STM32中各個(gè)模塊都有自己的時(shí)鐘,當(dāng)使用相應(yīng)的模塊時(shí)首先記得把此模塊時(shí)鐘開啟
本次學(xué)習(xí)使用標(biāo)準(zhǔn)固件庫(kù)3.3.0
好了,看明白上圖咱就開始吧:
void RCC_Configuration(void)
{
ErrorStatus HSEStartUpStatus;
//SystemInit();//完全可以使用此函數(shù)配置,但是為了學(xué)習(xí)咱先不用
RCC_DeInit();//復(fù)位RCC模塊的寄存器,復(fù)位成缺省值
RCC_HSEConfig(RCC_HSE_ON); //開啟HSE時(shí)鐘,咱是用HSE的時(shí)鐘作為PLL的時(shí)鐘源
HSEStartUpStatus = RCC_WaitForHSEStartUp();//獲取HSE啟動(dòng)狀態(tài)
if(HSEStartUpStatus == SUCCESS)//如果HSE啟動(dòng)成功
{
FLASH_PrefetchBufferCmd(ENABLE);//開啟FLASH的預(yù)取功能
FLASH_SetLatency(FLASH_Latency_2); //FLASH延遲2個(gè)周期(這里我也不明白,先用吧)
RCC_HCLKConfig(RCC_SYSCLK_Div1); //配置HCLK,PCLK2,PCLK1,PLL
RCC_PCLK2Config(RCC_HCLK_Div1);
RCC_PCLK1Config(RCC_HCLK_Div2);
RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);
RCC_PLLCmd(ENABLE);//啟動(dòng)PLL
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET)
{}//等待PLL啟動(dòng)完成
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //配置系統(tǒng)時(shí)鐘
while(RCC_GetSYSCLKSource() !=0x80) //檢查是否將HSE 9倍頻后作為系統(tǒng)時(shí)鐘
{}
}
}
設(shè)置時(shí)鐘流程:
1.將RCC寄存器重新設(shè)置為默認(rèn)值 RCC_DeInit
2.打開外部高速時(shí)鐘晶振HSE RCC_HSEConfig(RCC_HSE_ON);
3.等待外部高速時(shí)鐘晶振工作 HSEStartUpStatus = RCC_WaitForHSEStartUp();
4.設(shè)置AHB時(shí)鐘 RCC_HCLKConfig;
5.設(shè)置高速APB2時(shí)鐘RCC_PCLK2Config;
6.設(shè)置低速速APB1時(shí)鐘RCC_PCLK1Config
7.設(shè)置PLL RCC_PLLConfig
8.打開PLL RCC_PLLCmd(ENABLE);
9.等待PLL工作 while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
10.設(shè)置系統(tǒng)時(shí)鐘 RCC_SYSCLKConfig
11.判斷是否PLL是系統(tǒng)時(shí)鐘 while(RCC_GetSYSCLKSource() != 0x08)
12.打開要使用的外設(shè)時(shí)鐘 RCC_APB2PeriphClockCmd()/RCC_APB1PeriphClockCmd()
至此我們就將STM32的系統(tǒng)時(shí)鐘配置好了,系統(tǒng)時(shí)鐘72MHz,APH 72MHz,APB2 72MHz,APB1 32MHz,USB 48MHz
其他至于ADC什么的先用不管,用到時(shí)再設(shè)置,本次只是大體先熟悉下STM32的時(shí)鐘配置流程,便于以后程序的編寫
評(píng)論