高手帶你理解STM32系統(tǒng)時(shí)鐘和分頻
首先來(lái)手冊(cè)里的一段話。
三種不同的時(shí)鐘源可被用來(lái)驅(qū)動(dòng)系統(tǒng)時(shí)鐘 (SYSCLK)
· HSI振蕩器時(shí)鐘
· HSE振蕩器時(shí)鐘
· PLL時(shí)鐘
一般用的是PLL時(shí)鐘,后面有證據(jù)。
我們可以通過(guò)庫(kù)函數(shù)獲取各時(shí)鐘值
void RCC_GetClocksFreq(RCC_ClocksTypeDef* RCC_Clocks)
在我的系統(tǒng)里,把時(shí)鐘值打印信息如下:
SYSCLK:0x44aa200 //72000000, 72MHz
HCLK:0x44aa200 //72000000, 72MHz
PCLK1:0x2255100 //36000000, 36MHz
PCLK2:0x44aa200 //72000000, 72MHz
ADCCLK:0x2255100 //36000000,36MHz
RCC->CFGR:0x001D040A //PLL輸出作為系統(tǒng)時(shí)鐘
可推測(cè)幾個(gè)預(yù)分頻值為
AHB prescaler = 1
APB1 prescaler = 2
APB2 prescaler = 1
ADC prescaler = 2
根據(jù)讀取RCC->CFGR寄存器值為:0x001D040A,上面推測(cè)完全正確。
CFGR寄存器的SWS段也說(shuō)明:PLL輸出作為系統(tǒng)時(shí)鐘。
TIM2使用PCLK1,但注意時(shí)鐘樹(shù)里有這一段
見(jiàn)附圖
已知APB1 prescaler=2,故TIM2CLK = PCLK1*2 = 72MHz.
所以被TIM2分頻的時(shí)鐘大小是72MHz。
我的程序也證明了這點(diǎn)
TIM_TimeBaseInitTypeDef tim2_InitStruct;
TIM_DeInit(TIM2);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);//Enable Timer2 clock.
NVIC_ConfigurationForTimer2();
// PCLK1=36MHz, PSC=36000-1, CK_CNT=36MHz/(PSC+1)=1000
// ARR=2000, 1s/1000 * 2000 = 2s.
tim2_InitStruct.TIM_Prescaler = 36000-1;
tim2_InitStruct.TIM_Period = 2000-1;
tim2_InitStruct.TIM_CounterMode = TIM_CounterMode_Up;
tim2_InitStruct.TIM_ClockDivision = TIM_CKD_DIV1;
tim2_InitStruct.TIM_RepetitionCounter = 0;
TIM_TimeBaseInit(TIM2, &tim2_InitStruct);
TIM_ClearFlag(TIM2, TIM_FLAG_Update);
TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);//Enables the specified TIM interrupts.
這段配置原本以為定時(shí)時(shí)間是2s,實(shí)際只有1s?戳耸謨(cè)才理解原因。
編輯:admin 最后修改時(shí)間:2018-05-18