當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]STM32中在使用任何一個(gè)外設(shè)都必須打開(kāi)相應(yīng)的時(shí)鐘,所以我從STM32的時(shí)鐘學(xué)起。RCC時(shí)鐘在STM32中有5個(gè)時(shí)鐘源:①、HSI是高速內(nèi)部時(shí)鐘,RC震蕩器,頻率為 8MHz。②、HSE是高速外部時(shí)鐘,可接石英/陶瓷諧振器,或者接外部

STM32中在使用任何一個(gè)外設(shè)都必須打開(kāi)相應(yīng)的時(shí)鐘,所以我從STM32的時(shí)鐘學(xué)起。

RCC時(shí)鐘

在STM32中有5個(gè)時(shí)鐘源:①、HSI是高速內(nèi)部時(shí)鐘,RC震蕩器,頻率為 8MHz。②、HSE是高速外部時(shí)鐘,可接石英/陶瓷諧振器,或者接外部時(shí)鐘源,頻率范圍為4MHz~16MHz。③、LSI是低速內(nèi)部時(shí)鐘,RC振蕩器,頻率為40kHz。④、LSE是低速外部時(shí)鐘,接頻率為32.768kHz的石英晶體。⑤、PLL為鎖相環(huán)倍頻輸出,其時(shí)鐘輸入源可選擇為HIS/2、HSE或HSE/2。倍頻可選擇為2~16倍,但其輸出頻率最大不得超過(guò)72MHz。

系統(tǒng)時(shí)鐘SYSCLK,它是供STM32中絕大部分器件工作的時(shí)鐘源,系統(tǒng)時(shí)鐘可選擇為PLL輸出、HSI或者HSE。系統(tǒng)時(shí)鐘的做大頻率為72MHz,它通過(guò)AHB分頻器分頻后送給個(gè)模塊使用,AHB分頻器可選擇1、2、4、8、16、32、64、128、256、512分頻。AHB分頻器輸出的時(shí)鐘送給5大模塊使用:

1. 送給AHB總線、內(nèi)核、內(nèi)存和DMA使用的HCLK時(shí)鐘。2. 通過(guò)8分頻后送給Cortex的系統(tǒng)定時(shí)器時(shí)鐘。3. 直接送給Cortex的空閑運(yùn)行時(shí)鐘PCLK。4. 送給APB1分頻器。APB1分頻器可選擇1、2、4、8、16分頻,其輸出一路供APB1外設(shè)使用(PCLK1,最大頻率36MHz),另一路送給定時(shí)器(Timer)2、3、4倍頻器使用。該倍頻器可選擇1或者2倍頻,時(shí)鐘輸出供定時(shí)器2、3、4使用。5.送給APB2分頻器。APB2分頻器可選擇1、2、4、8、16分頻,其輸出一路供APB2外設(shè)使用(PCLK2,最大頻率72MHz),另一路送給定時(shí)器(Timer)1倍頻器使用。該倍頻器可選擇1或者2倍頻,時(shí)鐘輸出供定時(shí)器1使用。另外,APB2分頻器還有一路輸出供ADC分頻器使用,分頻后送給ADC模塊使用。ADC分頻器可選擇為2、4、6、8分頻。連接在APB1(低速外設(shè))上的設(shè)備有:電源接口、備份接口、CAN、USB、I2C1、I2C2、UART2、UART3、SPI2、窗口看門狗、Timer2、Timer3、Timer4。連接在APB2(高速外設(shè))上的設(shè)備有:UART1、SPI1、Timer1、ADC1、ADC2、所有普通IO口、第二功能IO口。寄存器描述:typedef struct
{
vu32 CR; //HSI,HSE,CSS,PLL等的使能
vu32 CFGR; //PLL等的時(shí)鐘源選擇以及分頻系數(shù)設(shè)定
vu32 CIR; //清除/使能時(shí)鐘就緒中斷
vu32 APB2RSTR; //APB2線上外設(shè)復(fù)位寄存器
vu32 APB1RSTR; //APB1線上外設(shè)復(fù)位寄存器
vu32 AHBENR; //DMA,SDIO等時(shí)鐘使能
vu32 APB2ENR; //APB2線上外設(shè)時(shí)鐘使能
vu32 APB1ENR; //APB1線上外設(shè)時(shí)鐘使能
vu32 BDCR; //備份域控制寄存器
vu32 CSR;
} RCC_TypeDef;

時(shí)鐘控制寄存器(RCC_CR)

31~26

25

24

23~20

19

18

17

16

保留

PLLRDY

PLLON

保留

CSSON

HSEBYP

HSERDY

HSEON

eg:RCC->CR|=0x00010000; //外部高速時(shí)鐘使能HSEON

RCC->CR|=0x01000000; //使能PLLON

RCC->CR>>25; //等待PLL鎖定

時(shí)鐘配置寄存器(RCC_CFGR)

31:27

26:24

23

22

21:18

17

16

保留

MCO[2:0]

保留

USBPRE

PLLMUL[3:0]

PLLXTPRE

PLLSRC

15:14

13:11

10:8

7:4

3:2

1:0

ADCPRE[1:0]

PPRE2[2:0]

PPRE1[2:0]

HPRE[3:0]

SWS[1:0]

SW[1:0]

位26:24

MCO: 微控制器時(shí)鐘輸出 (Microcontroller clock output)

由軟件置’1’或清零。

0xx:沒(méi)有時(shí)鐘輸出;

100:系統(tǒng)時(shí)鐘(SYSCLK)輸出;

101:內(nèi)部RC振蕩器時(shí)鐘(HSI)輸出;

110:外部振蕩器時(shí)鐘(HSE)輸出;

111:PLL時(shí)鐘2分頻后輸出。

位22

USBPRE:USB預(yù)分頻 (USB prescaler)

由軟件置’1’或清’0’來(lái)產(chǎn)生48MHz的USB時(shí)鐘。在RCC_APB1ENR寄存器中使能USB時(shí)鐘之前,必須保證該位已經(jīng)有效。如果USB時(shí)鐘被使能,該位不能被清零。

0:PLL時(shí)鐘1.5倍分頻作為USB時(shí)鐘

1:PLL時(shí)鐘直接作為USB時(shí)鐘

位21:18

PLLMUL:PLL倍頻系數(shù) (PLL multiplication factor)

由軟件設(shè)置來(lái)確定PLL倍頻系數(shù)。只有在PLL關(guān)閉的情況下才可被寫入。

注意:PLL的輸出頻率不能超過(guò)72MHz

0000:PLL 2倍頻輸出1000:PLL 10倍頻輸出

0001:PLL 3倍頻輸出1001:PLL 11倍頻輸出

0010:PLL 4倍頻輸出1010:PLL 12倍頻輸出

0011:PLL 5倍頻輸出1011:PLL 13倍頻輸出

0100:PLL 6倍頻輸出1100:PLL 14倍頻輸出

0101:PLL 7倍頻輸出1101:PLL 15倍頻輸出

0110:PLL 8倍頻輸出1110:PLL 16倍頻輸出

0111:PLL 9倍頻輸出1111:PLL 16倍頻輸出

位17

PLLXTPRE:HSE分頻器作為PLL輸入 (HSE divider for PLL entry)

由軟件置’1’或清’0’來(lái)分頻HSE后作為PLL輸入時(shí)鐘。只能在關(guān)閉PLL時(shí)才能寫入此位。

0:HSE不分頻

1:HSE 2分頻

位16

PLLSRC:PLL輸入時(shí)鐘源 (PLL entry clock source)

由軟件置’1’或清’0’來(lái)選擇PLL輸入時(shí)鐘源。只能在關(guān)閉PLL時(shí)才能寫入此位。

0:HSI振蕩器時(shí)鐘經(jīng)2分頻后作為PLL輸入時(shí)鐘

1:HSE時(shí)鐘作為PLL輸入時(shí)鐘。

位15:14

ADCPRE[1:0]:ADC預(yù)分頻 (ADC prescaler)

由軟件置’1’或清’0’來(lái)確定ADC時(shí)鐘頻率

00:PCLK2 2分頻后作為ADC時(shí)鐘

01:PCLK2 4分頻后作為ADC時(shí)鐘

10:PCLK2 6分頻后作為ADC時(shí)鐘

11:PCLK2 8分頻后作為ADC時(shí)鐘

位13:11

PPRE2[2:0]:高速APB預(yù)分頻(APB2) (APB high-speed prescaler (APB2))

由軟件置’1’或清’0’來(lái)控制高速APB2時(shí)鐘(PCLK2)的預(yù)分頻系數(shù)。

0xx:HCLK不分頻

100:HCLK 2分頻

101:HCLK 4分頻

110:HCLK 8分頻

111:HCLK 16分頻

位10:8

PPRE1[2:0]:低速APB預(yù)分頻(APB1) (APB low-speed prescaler (APB1))

由軟件置’1’或清’0’來(lái)控制低速APB1時(shí)鐘(PCLK1)的預(yù)分頻系數(shù)。

警告:軟件必須保證APB1時(shí)鐘頻率不超過(guò)36MHz。

0xx:HCLK不分頻

100:HCLK 2分頻

101:HCLK 4分頻

110:HCLK 8分頻

111:HCLK 16分頻

位7:4

HPRE[3:0]: AHB預(yù)分頻 (AHB Prescaler)

由軟件置’1’或清’0’來(lái)控制AHB時(shí)鐘的預(yù)分頻系數(shù)。

0xxx:SYSCLK不分頻

1000:SYSCLK 2分頻1100:SYSCLK 64分頻

1001:SYSCLK 4分頻1101:SYSCLK 128分頻

1010:SYSCLK 8分頻1110:SYSCLK 256分頻

1011:SYSCLK 16分頻1111:SYSCLK 512分頻

位3:2

SWS[1:0]:系統(tǒng)時(shí)鐘切換狀態(tài) (System clock switch status)

由硬件置’1’或清’0’來(lái)指示哪一個(gè)時(shí)鐘源被作為系統(tǒng)時(shí)鐘。

00:HSI作為系統(tǒng)時(shí)鐘;

01:HSE作為系統(tǒng)時(shí)鐘;

10:PLL輸出作為系統(tǒng)時(shí)鐘;

11:不可用。

位1:0

SW[1:0]:系統(tǒng)時(shí)鐘切換 (System clock switch)

由軟件置’1’或清’0’來(lái)選擇系統(tǒng)時(shí)鐘源。

00:HSI作為系統(tǒng)時(shí)鐘;

01:HSE作為系統(tǒng)時(shí)鐘;

10:PLL輸出作為系統(tǒng)時(shí)鐘;

11:不可用

eg: RCC->CFGR=0x00000400; //APB1=DIV2;APB2=DIV1(不分頻);AHB=DIV1(不分頻);

根據(jù)STM32庫(kù)函數(shù)設(shè)置時(shí)鐘流程:

RCC_DeInit(); //設(shè)置RCC寄存器重新設(shè)置為默認(rèn)值

RCC_HSEConfig(RCC_HSE_ON); //打開(kāi)外部高速時(shí)鐘晶振

HSEStartUpStatus = RCC_WaitForHSEStartUp(); //等待外部高速時(shí)鐘晶振工作

if(HSEStartUpStatus == SUCCESS) //外部就緒

{

//Add here PLL ans system clock config

RCC_HCLKConfig(RCC_SYSCLK_Div1); //設(shè)置AHB時(shí)鐘不分頻

RCC_PCLK2Config(RCC_HCLK_Div1); //設(shè)置APB2時(shí)鐘不分頻

RCC_PCLK1Config(RCC_HCLK_Div2); //設(shè)置APB1時(shí)鐘二分頻

RCC_ADCCLKConfig(RCC_PCLK2_Div6); //設(shè)置ADC時(shí)鐘六分頻

//設(shè)置PLL時(shí)鐘將8M時(shí)鐘9倍頻到72M

RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);

RCC_PLLCmd(ENABLE);//使能PLL

FlagStatus Status;

Status = RCC_GetFlagStatus(RCC_FLAG_PLLRDY);

if(Status == RESET)

{

……

}

RCC_SYSCLKConfig(RCC-SYSCLKSource_PLLCLK); //將PLL輸出設(shè)置為系統(tǒng)時(shí)鐘

while(RCC_GetSYSCLKSource()!=0x08) //測(cè)試PLL是否被用作系統(tǒng)時(shí)鐘等待校驗(yàn)完成

{}

}

else

{

//Add here some code to deal with this error

}

//使能外圍接口總線時(shí)鐘

RCC_APB2PeriphClockCmd() / RCC_APB1PeriphClockCmd()


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉