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

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

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

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

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

3)配置PLL1,同PLL0;

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

在轉載的LPC1788啟動代碼分析有提到啟動代碼程序完成如下內容的工作:

在Reset_Handler函數(shù)中會執(zhí)行SystemInit函數(shù),這個函數(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中,主要涉及到的時鐘配置宏如下:

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

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

#defineCLOCK_SETUP1
#defineSCS_Val0x00000021

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

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

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

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

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

PLL1為副振蕩器用于USB48M時鐘源輸入。

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

具體設置如下圖:

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時鐘選擇與分頻配置

CPU時鐘設置為1分頻=120MH,CPU時鐘分頻器時鐘源選型配置為PLL0,一般不改動。

#defineCCLKSEL_Val0x00000101

5.USB時鐘選擇與分頻配置

USB時鐘分頻器時鐘源選型配置為PLL1,一般不改動。

#defineUSBCLKSEL_Val0x00000201

6.EMC分頻配置

分頻=0,EMC與CPU使用同一個時鐘,

分頻=1,EMC使用CPU的一半時鐘。

根據(jù)需求配置。

以下配置結果為EMC=60M
#defineEMCCLKSEL_Val0x00000001

7.外設時鐘配置

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

以下配置結果為PCLK=60M
#definePCLKSEL_Val0x00000002

8.功耗模式配置

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

#definePCONP_Val0x042887DE

9.外部時鐘輸出配置

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

以下配置結果為0100選擇RTC振蕩器作為CLKOUT的時鐘源
#defineCLKOUTCFG_Val0x00000100

參考文獻:http://hi.baidu.com/lichy2012/item/77879bd1961dd114d90e449a

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


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

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

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

關鍵字: 汽車 人工智能 智能驅動 BSP

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

關鍵字: 亞馬遜 解密 控制平面 BSP

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

關鍵字: 騰訊 編碼器 CPU

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

關鍵字: 華為 12nm EDA 半導體

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

關鍵字: 華為 12nm 手機 衛(wèi)星通信

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

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

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

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

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

關鍵字: BSP 信息技術
關閉
關閉