0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RCC時鐘基礎(chǔ)知識和常見問題

FPGA之家 ? 來源:FPGA之家 ? 2023-10-16 16:48 ? 次閱讀

RCC,Reset and Clock Control(復(fù)位和時鐘控制),在絕大部分MCU芯片中都包含復(fù)位和時鐘控制模塊,也是MCU重要的組成部分。

相比于以前51單片機(jī),現(xiàn)在STM32內(nèi)部集成的時鐘模塊功能更加豐富,包含時鐘選擇、倍頻、輸出、外設(shè)總線時鐘配置等。

STM32 時鐘基礎(chǔ)內(nèi)容

STM32時鐘樹具有多項(xiàng)功能,可通過分頻和倍頻配置系統(tǒng)以及外設(shè)的時鐘頻率,不同型號STM32的時鐘樹有所不同。

1. 時鐘源

STM32的時鐘源分為高速、低速兩類時鐘,同時也分內(nèi)部和外部。

HSE:High Speed External,高速外部

HSI:High Speed Internal,高速內(nèi)部

LSE:Low Speed External ,低速外部

LSI:Low Speed Internal,低速內(nèi)部

HSE時鐘有兩類時鐘源:

外部晶振/陶瓷諧振器

外部用戶時鐘

b10798c2-6bf9-11ee-939d-92fbcf53809c.png

諧振器和負(fù)載電容要求必須盡可能地靠近振蕩器的引腳,減少失真和起振時間。外部用戶時鐘必須使用占空比約為 50% (左右)外部時鐘信號來驅(qū)動 OSC_IN 引腳,同時 OSC_OUT 引腳應(yīng)保持為高阻態(tài)。

2. 時鐘選擇

STM32高速時鐘默認(rèn)為高速內(nèi)部時鐘(HSI),如果外接有HSE,可通過軟件配置選擇HSE。

低速內(nèi)部時鐘(LSI)默認(rèn)是關(guān)閉的,如果需要使用速度時鐘,可通過軟件選擇并開啟LSI,也可以選擇使用LSE。

不管是高速還是低速,在不考慮硬件成本的前提下,建議使用精度更高,誤差更小的外部(HSE、LSE)時鐘。

3. 時鐘源輸出

STM32支持MCO引腳輸出時鐘信號,供外部器件使用,同時可通過示波器來測量內(nèi)部的各項(xiàng)時鐘。

輸出時鐘信號可選擇(HSE、LSE、 PLLCLK)不同來源的信號,同時也支持配置分頻值,這樣就可以盡量滿足輸出時鐘要求。

4. 時鐘分頻和倍頻

STM32的分頻和倍頻功能非常強(qiáng)大,可將時鐘源通過分頻與倍頻技術(shù),使各APB總線時鐘頻率配置為指定值,供各外設(shè)使用。

重點(diǎn)就是PLL(鎖相環(huán))的幾個參數(shù):PLL_M、PLL_N、PLL_P、PLL_Q,也就是倍頻、分頻因子。

STM32系統(tǒng)時鐘頻率理論上可以超過官方指定的最大值,比如:STM32F103最大72M,你倍頻為96M也可能正常工作,但實(shí)際應(yīng)用存在風(fēng)險(xiǎn)。

5. 時鐘安全系統(tǒng)

STM32的還有一個重要的功能,就是時鐘安全系統(tǒng)。如果使能了該功能,HSE 時鐘發(fā)生故障,將生成一個中斷來向軟件通知此故障,同時,系統(tǒng)時鐘將切換到 HSI 。

通過STM32時鐘樹,可以一目了然STM32時鐘的功能,比如STM32F4系列時鐘樹:

b112cae4-6bf9-11ee-939d-92fbcf53809c.png

更多關(guān)于STM32時鐘的信息,可以參看芯片對應(yīng)的參考手冊。

STM32 時鐘常規(guī)配置

STM32 系統(tǒng)時鐘配置在上電之后,初始化外設(shè)之前就要做的一件事。重點(diǎn)配置的內(nèi)容就是上面提到的基礎(chǔ)內(nèi)容,時鐘選擇、倍頻分頻,以及系統(tǒng)和外設(shè)的時鐘頻率等。

1. 標(biāo)準(zhǔn)外設(shè)庫配置時鐘

STM32F0、 F1、 F2、 F3、 F4、 L1系列都有標(biāo)準(zhǔn)外設(shè)庫,如果外部高速時鐘頻率和官方一致,就可以直接使用標(biāo)準(zhǔn)外設(shè)庫中的代碼。

b123a120-6bf9-11ee-939d-92fbcf53809c.png

地址:

https://www.st.com/en/embedded-software/stm32-standard-peripheral-libraries.html

具體為system_stm32fxxx.c中的 SystemInit 和 SetSysClock 函數(shù)。

如果你的外部高速時鐘頻率和代碼不對應(yīng),需要修改對應(yīng)的參數(shù)。比如:STM32F407外部晶振頻率默認(rèn)25M,如果你硬件使用12M,則需要修改分頻和倍頻值(也就是那幾個決定時鐘頻率的參數(shù))。

2. STM32CubeMX配置時鐘

使用STM32CubeMX配置時鐘,通過圖形化界面,一目了然,非常方便。如果配置錯誤,還會有“紫色”提醒。

比如:STM32F407時鐘樹配置:

b141f274-6bf9-11ee-939d-92fbcf53809c.png

生成的代碼默認(rèn)在 main.c 文件中的 SystemClock_Config 函數(shù)。

提示:分頻和倍頻因子的值不能太大,也不能大小,建議參考官方例程的參考值。

STM32 時鐘常見問題

STM32時鐘模塊一旦出問題就可能引起系統(tǒng)的不正常工作,特別是對時鐘敏感的部分。比如:定時器、串口波特率、I2C時鐘等。

問題一:主頻變慢問題

主頻,指CPU的時鐘頻率,或者系統(tǒng)時鐘。主頻變慢通常表現(xiàn)為程序運(yùn)行慢、卡頓、通信異常等。

通常引起主頻變慢的原因有:

時鐘源選擇不對;

外時鐘振頻率和軟件配置不對;

分頻和倍頻因子不對;

外部晶振電路不對;

測量主頻是否變慢,最直接的方法是通過配置MCO,輸出內(nèi)部PLLCLK時鐘(或HSE時鐘),用示波器(或邏輯分析儀)測量其頻率。

問題二:外設(shè)總線APB時鐘不同的問題

看到很多人遇到過這樣的問題:TIM定時快(或慢)一半。

這個問題的原因:STM32的APB時鐘存在“x2”的問題。

b152dfa8-6bf9-11ee-939d-92fbcf53809c.png

也就是說:如果APB分頻值等于1,則x1;APB分頻值不等于1,則x2。用一張動畫來說明:

b16e3e7e-6bf9-11ee-939d-92fbcf53809c.gif

因此,移植代碼的時候,一定要注意時鐘源(頻率),否則就會快(或慢)一倍的問題。

問題三:外部高速時鐘失效的問題

STM32通常會使用外部晶振作為高速時鐘,如果外部時鐘失效,程序可能表現(xiàn)為“卡頓”的現(xiàn)象。

出現(xiàn)這個問題有可能是外界環(huán)境干擾,或者晶振質(zhì)量問題。此時,應(yīng)該使能CSS(Clock Security System)時鐘安全系統(tǒng)功能。

使能CSS功能之后,可以做到:

程序進(jìn)入 NMI 中斷,通過程序判斷 HSE 是否失效;

切換到 HSI 作為時鐘源,重新配置時鐘并啟動程序;

b18ec662-6bf9-11ee-939d-92fbcf53809c.png

這樣就能讓“死程序”變活,然后程序照常執(zhí)行。

提示:CSS功能默認(rèn)是關(guān)閉的。標(biāo)準(zhǔn)外設(shè)庫中系統(tǒng)初始化代碼默認(rèn)配置開啟CSS,STM32CubeMX默認(rèn)配置是關(guān)閉的。

復(fù)盤一下

▼時鐘基礎(chǔ)內(nèi)容:時鐘源、時鐘選擇、時鐘源輸出、時鐘分頻和倍頻、時鐘安全系統(tǒng);

▼時鐘常規(guī)配置:標(biāo)準(zhǔn)外設(shè)庫和STM32CubeMX配置時鐘;

▼時鐘常見問題:主頻變慢問題、APB時鐘不同的問題、外部高速時鐘失效的問題;

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • STM32
    +關(guān)注

    關(guān)注

    2264

    文章

    10854

    瀏覽量

    354305
  • RCC
    RCC
    +關(guān)注

    關(guān)注

    0

    文章

    93

    瀏覽量

    26877
  • 時鐘源
    +關(guān)注

    關(guān)注

    0

    文章

    92

    瀏覽量

    15921

原文標(biāo)題:從小白到 Pro | RCC時鐘基礎(chǔ)知識和常見問題

文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    C語言基礎(chǔ)知識科普

    C語言是單片機(jī)開發(fā)中的必備基礎(chǔ)知識,本文列舉了部分STM32學(xué)習(xí)中比較常見的一些C語言基礎(chǔ)知識。
    發(fā)表于 07-21 10:58 ?1864次閱讀

    ADI工程師內(nèi)部整理【時鐘芯片常見問題解答】

    ,包括參考源、參考分頻、鑒相器、環(huán)路濾波器、壓控振蕩器等都對最終 PLL 的輸出貢獻(xiàn)噪聲。 那么問題來了,使用時鐘芯片時,你都遇到過哪些讓人抓狂的問題呢? ADI工程師內(nèi)容整里的【時鐘芯片常見問題
    發(fā)表于 05-20 10:30

    防雷接地基礎(chǔ)知識GJ1001

    GJ1001防雷接地基礎(chǔ)知識:您知道通信設(shè)備為什么需要接地嗎?熟悉通信局站的防雷接地以及設(shè)備的防雷措施,掌握防雷接地常見問題處理方法您知道雷電是怎么產(chǎn)生的嗎?
    發(fā)表于 05-21 18:36 ?52次下載
    防雷接地<b class='flag-5'>基礎(chǔ)知識</b>GJ1001

    PCBA(組裝)基礎(chǔ)知識簡介

    PCBA基礎(chǔ)知識常見缺陷可能形成的原因及對策
    發(fā)表于 11-20 16:01 ?0次下載

    RCC系統(tǒng)時鐘的stm32例程

    關(guān)于RCC系統(tǒng)時鐘的stm32例程是一個完整的程序,可以運(yùn)行的
    發(fā)表于 12-07 14:33 ?16次下載

    STM32時鐘基礎(chǔ)內(nèi)容和常見問題

    RCC,Reset and Clock Control(復(fù)位和時鐘控制),在絕大部分MCU芯片中都包含復(fù)位和時鐘控制模塊,也是MCU重要的組成部分。 相比于以前51單片機(jī),現(xiàn)在STM32內(nèi)部集成
    的頭像 發(fā)表于 04-02 16:39 ?6140次閱讀
    STM32<b class='flag-5'>時鐘</b>基礎(chǔ)內(nèi)容和<b class='flag-5'>常見問題</b>

    寬帶RF PLL+VCO和時鐘產(chǎn)生產(chǎn)品常見問題

    寬帶RF PLL+VCO和時鐘產(chǎn)生產(chǎn)品常見問題
    發(fā)表于 05-22 17:51 ?8次下載
    寬帶RF PLL+VCO和<b class='flag-5'>時鐘</b>產(chǎn)生產(chǎn)品<b class='flag-5'>常見問題</b>

    STM32的時鐘系統(tǒng)RCC詳細(xì)整理

    STM32的時鐘系統(tǒng)RCC詳細(xì)整理
    發(fā)表于 11-20 12:06 ?10次下載
    STM32的<b class='flag-5'>時鐘</b>系統(tǒng)<b class='flag-5'>RCC</b>詳細(xì)整理

    STM32F429--RCC時鐘

    RCC時鐘樹的簡單分析
    發(fā)表于 11-29 16:36 ?7次下載
    STM32F429--<b class='flag-5'>RCC</b><b class='flag-5'>時鐘</b>樹

    STM32系統(tǒng)時鐘RCC詳解

    【STM32】系統(tǒng)時鐘RCC詳解(超詳細(xì),超全面) 原創(chuàng)
    發(fā)表于 11-30 12:21 ?14次下載
    STM32系統(tǒng)<b class='flag-5'>時鐘</b><b class='flag-5'>RCC</b>詳解

    如何解決PCIe時序設(shè)計(jì)的常見問題

    另一個常見問題是,當(dāng)輸入?yún)⒖?b class='flag-5'>時鐘消失時,時鐘芯片的輸出會停滯在高/低或低/高狀態(tài)。HCSL 拓?fù)渚哂凶匀魂P(guān)閉特性,當(dāng)它們被禁用時使用低/低狀態(tài)。
    的頭像 發(fā)表于 04-22 15:16 ?3458次閱讀
    如何解決PCIe時序設(shè)計(jì)的<b class='flag-5'>常見問題</b>

    時鐘抖動解秘—高速鏈路時鐘抖動規(guī)范基礎(chǔ)知識

    時鐘抖動解秘—高速鏈路時鐘抖動規(guī)范基礎(chǔ)知識
    發(fā)表于 11-07 08:07 ?2次下載
    <b class='flag-5'>時鐘</b>抖動解秘—高速鏈路<b class='flag-5'>時鐘</b>抖動規(guī)范<b class='flag-5'>基礎(chǔ)知識</b>

    復(fù)位和時鐘控制RCC課件下載

    電子發(fā)燒友網(wǎng)站提供《復(fù)位和時鐘控制RCC課件下載.pdf》資料免費(fèi)下載
    發(fā)表于 08-01 09:48 ?0次下載
    復(fù)位和<b class='flag-5'>時鐘</b>控制<b class='flag-5'>RCC</b>課件下載

    如何解決同步時鐘系統(tǒng)中的常見問題和故障?

    同步時鐘系統(tǒng) 在電力、通信、交通等領(lǐng)域中應(yīng)用廣泛,為保證其正常運(yùn)行,需要進(jìn)行系統(tǒng)的維護(hù)和保養(yǎng)。下面是述泰時鐘總結(jié)的時鐘同步系統(tǒng)維護(hù)常見問題及解決方法的介紹。
    的頭像 發(fā)表于 03-19 10:42 ?1297次閱讀
    如何解決同步<b class='flag-5'>時鐘</b>系統(tǒng)中的<b class='flag-5'>常見問題</b>和故障?

    熱釋電傳感器基本知識和使用中的常見問題

    電子發(fā)燒友網(wǎng)站提供《熱釋電傳感器基本知識和使用中的常見問題》資料免費(fèi)下載
    發(fā)表于 06-11 09:06 ?1次下載