當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]LPC1788有3個(gè)獨(dú)立的振蕩器。他們是主振蕩器,內(nèi)部RC振蕩器,RTC振蕩器。復(fù)位后,LPC1788將用內(nèi)部的RC振蕩器運(yùn)行,直到被軟件切換。這樣就能在沒有任何外部晶振的情況下運(yùn)行。LPC1788的時(shí)鐘控制如圖1所示(英文手冊(cè)P3

LPC1788有3個(gè)獨(dú)立的振蕩器。他們是主振蕩器,內(nèi)部RC振蕩器,RTC振蕩器。復(fù)位后,LPC1788將用內(nèi)部的RC振蕩器運(yùn)行,直到被軟件切換。這樣就能在沒有任何外部晶振的情況下運(yùn)行。LPC1788的時(shí)鐘控制如圖1所示(英文手冊(cè)P35):

使用12M的晶振作為主振蕩器,它通過鎖相環(huán)PLL0來提高頻率提供CPU。由于芯片總是從內(nèi)部的RC振蕩器開始工作,因此主振蕩器只會(huì)應(yīng)軟件的請(qǐng)求而啟動(dòng)。實(shí)現(xiàn)方法是設(shè)定SCS寄存器中的OSCEN位使能。主振蕩器提供一個(gè)狀態(tài)標(biāo)志SCS寄存器的OSCSTAT位,這樣軟件就可以確定何時(shí)主振蕩器在運(yùn)行穩(wěn)定。此時(shí),軟件可以控制切換到主振蕩器,使其作為時(shí)鐘源。在啟動(dòng)以前,必須通過SCS的OSCRANGE位,選擇一個(gè)頻率范圍。在確定了主振蕩器之后,需要進(jìn)行鎖相環(huán)的配置。

1) 配置CLKSRCSEL選擇正確的時(shí)鐘源,內(nèi)部振蕩器切換為主振蕩器(osc_clk);

2)配置PLL0將正確的PLL0設(shè)置值寫入PLL0CFG寄存器并且在PLL0CON中使能PLL0,向PLLFEED寄存器中寫入饋送序列0xAA,0x55;

3)配置PLL1,同PLL0;

4)設(shè)置所需的時(shí)鐘分配器如CCLKSEL,PCLSEL,EMCCLKSEL,以及USBCLKSEL寄存器。

在轉(zhuǎn)載的LPC1788啟動(dòng)代碼分析有提到啟動(dòng)代碼程序完成如下內(nèi)容的工作:

在Reset_Handler函數(shù)中會(huì)執(zhí)行SystemInit函數(shù),這個(gè)函數(shù)在文件system_LPC177x_8x.c中。

#define CLOCK_SETUP 1

#define SCS_Val 0x00000021

#define PLL0_SETUP 1

#define PLL0CFG_Val 0x00000009

#define PLL1_SETUP 1

#define PLL1CFG_Val 0x00000023

#define CCLKSEL_Val (0x00000001|(1<<8))

#define USBCLK_SETUP 1

#define USBCLKSEL_Val (0x00000001|(0x02<<8))

#define EMCCLKSEL_Val 0x00000001

#define PCLKSEL_Val 0x00000002

#define PCONP_Val 0x042887DE

#define CLKOUTCFG_Val 0x00000100

voidSystemInit(void)

{

#if (CLOCK_SETUP) /* Clock Setup */

LPC_SC->SCS = SCS_Val;

if (SCS_Val & (1 << 5)) { /* If Main Oscillator is enabled */

while ((LPC_SC->SCS & (1<<6)) == 0);/* Wait for Oscillator to be ready */

}

LPC_SC->CLKSRCSEL = CLKSRCSEL_Val; /* Select Clock Source for sysclk/PLL0*/

#if (PLL0_SETUP)

LPC_SC->PLL0CFG = PLL0CFG_Val;

LPC_SC->PLL0CON = 0x01; /* PLL0 Enable */

LPC_SC->PLL0FEED = 0xAA;

LPC_SC->PLL0FEED = 0x55;

while (!(LPC_SC->PLL0STAT & (1<<10)));/* Wait for PLOCK0 */

#endif

#if (PLL1_SETUP)

LPC_SC->PLL1CFG = PLL1CFG_Val;

LPC_SC->PLL1CON = 0x01; /* PLL1 Enable */

LPC_SC->PLL1FEED = 0xAA;

LPC_SC->PLL1FEED = 0x55;

while (!(LPC_SC->PLL1STAT & (1<<10)));/* Wait for PLOCK1 */

#endif

LPC_SC->CCLKSEL = CCLKSEL_Val; /* Setup Clock Divider */

LPC_SC->USBCLKSEL = USBCLKSEL_Val; /* Setup USB Clock Divider */

LPC_SC->EMCCLKSEL = EMCCLKSEL_Val; /* EMC Clock Selection */

LPC_SC->PCLKSEL = PCLKSEL_Val; /* Peripheral Clock Selection */

LPC_SC->PCONP = PCONP_Val; /* Power Control for Peripherals */

LPC_SC->CLKOUTCFG = CLKOUTCFG_Val; /* Clock Output Configuration */

#endif

#if (FLASH_SETUP == 1) /* Flash Accelerator Setup */

LPC_SC->FLASHCFG = FLASHCFG_Val|0x03A;

#endif

#ifdef __RAM_MODE__

SCB->VTOR = 0x10000000 & 0x3FFFFF80;

#else

SCB->VTOR = 0x00000000 & 0x3FFFFF80;

#endif

}

在system_LPC177x_8x.c中,主要涉及到的時(shí)鐘配置宏如下:

1.系統(tǒng)時(shí)鐘控制器的配置

系統(tǒng)控制與狀態(tài)寄存器(SCS—0x400FC1A0),一般以下這一項(xiàng),我們不用修改。需要注意的是BIT4位的振蕩器的頻率范圍選擇,根據(jù)具體情況而定,具體設(shè)置如下圖:

#defineCLOCK_SETUP1
#defineSCS_Val0x00000021

2.系統(tǒng)時(shí)鐘源配置

val=0,選擇內(nèi)部RC振蕩器作為系統(tǒng)時(shí)鐘和PLL0的時(shí)鐘源(默認(rèn))。

val=1,選擇主振蕩器作為系統(tǒng)時(shí)鐘和PLL0的時(shí)鐘源。
#defineCLKSRCSEL_Val0x00000001

3.系統(tǒng)PLL0以及PLL1配置

PLL0為主振蕩器用于系統(tǒng)主時(shí)鐘輸入源。

PLL1為副振蕩器用于USB48M時(shí)鐘源輸入。

以下參數(shù)配置的結(jié)果為系統(tǒng)時(shí)鐘=120M

具體設(shè)置如下圖:

The value written to the MSEL bits in the PLLCFG register is M -1

LPC_SC->PLL0CFG =0x00000009配置為120Mhz 12mhz*(9+1)

#definePLL0_SETUP1
#definePLL0CFG_Val0x00000009
#definePLL1_SETUP1
#definePLL1CFG_Val0x00000023

4.CPU時(shí)鐘選擇與分頻配置

CPU時(shí)鐘設(shè)置為1分頻=120MH,CPU時(shí)鐘分頻器時(shí)鐘源選型配置為PLL0,一般不改動(dòng)。

#defineCCLKSEL_Val0x00000101

5.USB時(shí)鐘選擇與分頻配置

USB時(shí)鐘分頻器時(shí)鐘源選型配置為PLL1,一般不改動(dòng)。

#defineUSBCLKSEL_Val0x00000201

6.EMC分頻配置

分頻=0,EMC與CPU使用同一個(gè)時(shí)鐘,

分頻=1,EMC使用CPU的一半時(shí)鐘。

根據(jù)需求配置。

以下配置結(jié)果為EMC=60M
#defineEMCCLKSEL_Val0x00000001

7.外設(shè)時(shí)鐘配置

范圍(1-31)根據(jù)需求配置。

以下配置結(jié)果為PCLK=60M
#definePCLKSEL_Val0x00000002

8.功耗模式配置

一般不用修改,若需要用到低功耗,則按需修改:

#definePCONP_Val0x042887DE

9.外部時(shí)鐘輸出配置

為了便于系統(tǒng)測試與開發(fā),任何一種內(nèi)部時(shí)鐘均可引入CLKOUT功能(在P1[25]或P1[27]管腳可使用),根據(jù)需求配置。

以下配置結(jié)果為0100選擇RTC振蕩器作為CLKOUT的時(shí)鐘源
#defineCLKOUTCFG_Val0x00000100

參考文獻(xiàn):http://hi.baidu.com/lichy2012/item/77879bd1961dd114d90e449a

http://www.cnblogs.com/tdyizhen1314/archive/2012/09/26/2703310.html


本站聲明: 本文章由作者或相關(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日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

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

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(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ì)日本游戲市場的投資。

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

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

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

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

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

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

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

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

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

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

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