之前寫過一篇關于時鐘引腳的文章 《i.MXRT1xxx系列MCU時鐘相關功能引腳的作用》,里面簡單提及了外部晶振相關引腳的作用,但是并沒有詳細展開。
最近在客戶支持中,有客戶咨詢項目板級設計上能否將外部24MHz晶振完全去掉。
今天就這個話題,使用芯片內部集成的RC24M做初始時鐘源,詳細展開,好好地聊聊。
注:本文中圖片代碼均以i.MX RT1050為例,但內容基本也適用其它i.MX RT10xx系列。
1外部24MHz晶振的作用
i.MXRT 系列共有兩組外接晶振專用引腳,XTALI/O用于外部連接24MHz晶振,RTC_XTALI/O用于連接32.768kHz晶振。其中低頻的32.768kHz晶振主要用于低功耗場景(SNVS 域),而高頻24MHz晶振(即本文主角)主要是給內部PLL提供時鐘源,它是高性能應用的保證。
注: i.MX RT1011/102x的PLL時鐘源僅能是OSC 24MHz,而 i.MX RT105x/106x的PLL時鐘源除了OSC 24MHz外,還可以是專門時鐘輸入引腳(CLK1_P/N)。
外部24MHz晶振(XTAL24M)并不是直接連到PLL模塊的,中間會經(jīng)過芯片內部OSC 24MHz模塊,而OSC 24MHz模塊本身還包含了一個RC24M震蕩電路,這是為了確保在沒有外部XTAL24M的情況下,PLL也能正常工作。
注1: OSC 24MHz模塊的源可來自外部XTAL24M也可以是內部RC24M,但這種切換不是自動的,需要在代碼里主動切換。
注2: RC24M主要用于低速應用場合,并且以RC24M為源的功耗比以XTAL24M為源的功耗小很多。
2內部RC24M振蕩器能否替代外部24MHz晶振?
我們知道內部RC24M精度較差,最差的情況甚至有20%的精度誤差,這種情況下一些對精度要求高的外設(比如USB、ENET)是無法使用RC24M為源的PLL輸出作為時鐘源的。
如果你的應用里不涉及USB、ENET等外設,就使用了一些簡單的LPUART/LPSPI等外設,那么是完全可以禁掉外部XTAL24M的使用的,切換代碼如下。
其中需要注意的是如果當前內核時鐘源來自PLL,那么必須先將內核時鐘切到OSC24M,否則OSC24M時鐘源切換操作會直接導致代碼跑飛(一旦PLL時鐘源發(fā)生變化,輸出會不穩(wěn),此時內核運行會出現(xiàn)異常):
void ClockSelectRcOsc(void) { // 將內核時鐘源從 PLL 切換到 OSC 24M CLOCK_SetMux(kCLOCK_PeriphClk2Mux, 1); CLOCK_SetMux(kCLOCK_PeriphMux, 1); // 將 OSC 24M 時鐘源從外部 XTAL24 切換到內部 RC24M CLOCK_InitRcOsc24M(); CLOCK_SwitchOsc(kCLOCK_RcOsc); CLOCK_DeinitExternalClk(); // 恢復內核時鐘源(這里的 m、n 為切換之前的配置) CLOCK_SetMux(kCLOCK_PeriphClk2Mux, m); CLOCK_SetMux(kCLOCK_PeriphMux, n); }
更多RC24M的應用詳見 SDK_2_12_0_EVKB-IMXRT1050oardsevkbimxrt1050demo_appspower_mode_switchm 例程。
3能否完全去掉外部24MHz晶振?
既然在低速或者低功耗應用場合,RC24M可以替代XTAL24M,那么我們能不能直接把XTAL24M完全去掉呢?答案很遺憾,不能!因為芯片系統(tǒng)(內核、PLL)默認就是以 XTAL24M為初始時鐘源:
XTALOSC24M->LOWPWR_CTRL[OSC_SEL] = 1'b0 // 24MHz clock from XTAL OSC CCM_ANALOG->PLL_ARM[BYPASS_CLK_SRC] = 2'b00 // clock from REF_CLK_24M CCM->CBCMR[PRE_PERIPH_CLK_SEL] = 2'b11 // clock from divided PLL1 (PLL_ARM) CCM->CBCDR[PERIPH_CLK_SEL] = 1'b0 // clock from pre_periph_clk_sel
如果沒有外部XTAL24M,芯片系統(tǒng)上電后,內核沒有正確的時鐘源,BootROM代碼無法正常執(zhí)行,這時候甚至仿真器也沒法找到內核,所有后續(xù)設計也就沒有任何意義。
看到這里,你可能會明白,i.MX RT畢竟是跨界處理器,它是為高性能場景而生的,運行起來后切換到內部RC24M來降功耗只是它的附帶功能而已。
-
芯片
+關注
關注
455文章
50714瀏覽量
423136 -
mcu
+關注
關注
146文章
17123瀏覽量
350978 -
晶振
+關注
關注
34文章
2859瀏覽量
68004 -
時鐘
+關注
關注
10文章
1733瀏覽量
131446
原文標題:淺談i.MX RT10xx系列MCU外接24MHz晶振的作用
文章出處:【微信號:NXP_SMART_HARDWARE,微信公眾號:恩智浦MCU加油站】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論