www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 單片機 > 單片機
[導讀]本文結合網(wǎng)上的兩篇時鐘分析文章,并結合本人的理解來分析STM32的時鐘系統(tǒng)。眾所周知,一個微控制器或處理器的運行必須要依賴周期性的時鐘脈沖來驅動,通常是通過外接晶振來實現(xiàn)的。在學習單片機(51系列,AVR系列,

本文結合網(wǎng)上的兩篇時鐘分析文章,并結合本人的理解來分析STM32的時鐘系統(tǒng)。

眾所周知,一個微控制器或處理器的運行必須要依賴周期性的時鐘脈沖來驅動,通常是通過外接晶振來實現(xiàn)的。在學習單片機(51系列,AVR系列,PIC系列)的過程中,只要設定了外接晶振,我們就只關心的時序圖,無需再進行時鐘的配置,而STM32微控制器的時鐘樹則是可配置的,其時鐘輸入源與最終達到外設處的時鐘速率不再有固定的關系,本文將來詳細解析STM32微控制器的時鐘樹。

在官方提供的STM32參考手冊或數(shù)據(jù)手冊中,提供了如下的時鐘樹結構圖:

為了方便分析,簡化為如下的時鐘樹,


由圖可知:STM32主要有5個時鐘源,分別為HSI、HSE、LSI、LSE、PLL,如灰藍色如示,而PLL是由鎖相環(huán)電路倍頻得到PLL時鐘。從上到下分析,分別 為:

HSI是高速內部時鐘,內置RC振蕩器,頻率為8MHz;

HSE是高速外部時鐘,可接石英/陶瓷諧振器,或者接外部時鐘源,頻率范圍為4MHz~16MHz,一般接8MHz石英晶振;

LSE是低速外部時鐘,接頻率為32.768kHz的石英晶體,主要提供一個精確的時鐘源一般作為RTC時鐘使用;

LSI是低速內部時鐘,RC振蕩器,頻率為40kHz。它供獨立看門狗IWDG使用,另外它還可以被選擇為實時時鐘RTC的時鐘源。另外,實時時鐘RTC的時鐘源還可以選擇LSE,或者是HSE的128分頻。RTC的時鐘源通過RTCSEL[1:0]來選擇;

PLL為鎖相環(huán)倍頻輸出,其時鐘輸入源可選擇為HSI/2、HSE或者HSE/2,倍頻可選擇為2~16倍,但是其輸出頻率最大不得超過72MHz。


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


送給AHB總線、內核、內存和DMA使用的HCLK時鐘;

通過8分頻后送給Cortex的系統(tǒng)定時器時鐘;

直接送給Cortex的空閑運行時鐘FCLK;

送給APB1分頻器。APB1分頻器可選擇1、2、4、8、16分頻,其輸出一路供APB1外設使用(PCLK1,最大頻率36MHz),另一路送給定時器(Timer)2、3、4倍頻器使用。該倍頻器可選擇1或者2倍頻,時鐘輸出供定時器2、3、4使用;

送給APB2分頻器。APB2分頻器可選擇1、2、4、8、16分頻,其輸出一路供APB2外設使用(PCLK2,最大頻率72MHz),另一路送給定時器(Timer)1倍頻器使用。該倍頻器可選擇1或者2倍頻,時鐘輸出供定時器1使用。另外,APB2分頻器還有一路輸出供ADC分頻器使用,分頻后送給ADC模塊使用。ADC分頻器可選擇為2、4、6、8分頻。


另外:

(1)STM32中有一個全速功能的USB模塊,其串行接口引擎需要一個頻率為48MHz的時鐘源。該時鐘源只能從PLL輸出端獲取,可以選擇為1.5分頻或者1分頻,也就是,當需要使用USB模塊時,PLL必須使能,并且時鐘頻率配置為48MHz或72MHz。
(2)STM32還可以選擇一個時鐘信號輸出到MCO腳(PA8)上,可以選擇為PLL輸出的2分頻、HSI、HSE、或者系統(tǒng)時鐘。

在STM32處理器,對應每一模塊,都需要為其配置時鐘源,我們將官方提供的時鐘樹再進行細化,就得到如下的時鐘樹,其中圖中的標號分別為:1:內部低速振蕩器(LSI,40Khz);2:外部低速振蕩器(LSE,32.768Khz);3:外部高速振蕩器(HSE,3-25MHz);4:內部高速振蕩器(HIS,8MHz);5:PLL輸入選擇位;6:RTC時鐘選擇位;7:PLL1分頻數(shù)寄存器;8:PLL1倍頻寄存器;9:系統(tǒng)時鐘選擇位;10:USB分頻寄存器;11:AHB分頻寄存器;12:APB1分頻寄存器;13:AHB總線;14:APB1外設總線;15:APB2分頻寄存器;16:APB2外設總線;17:ADC預分頻寄存器;18:ADC外設;19:PLL2分頻數(shù)寄存器;20:PLL2倍頻寄存器;21:PLL時鐘源選擇寄存器;22:獨立看門狗設備;23:RTC設備



假設我們要設置位于APB2控制的GPIO外設時鐘,則我們得到的時鐘軌跡應該是:3-->5-->7-->21-->8-->9-->11-->15-->16。即:首先(3)是外部的3-25MHz(前文已假設為8MHz)輸入;通過(5)PLL選擇位預先選擇后續(xù)PLL分支的輸入時鐘(假設選擇外部晶振);設置(7)外部晶振的分頻數(shù)(假設1分頻);選擇(21)PLL倍頻的時鐘源(假設選擇經(jīng)過分頻后的外部晶振時鐘);對于8,設置(8)PLL倍頻數(shù)(假設9倍頻);選擇(9)系統(tǒng)時鐘源(假設選擇經(jīng)過PLL倍頻所輸出的時鐘);設置(11)AHB總線分頻數(shù)(假設1分頻);設置(15)APB2總線分頻數(shù)(假設1分頻);時鐘到達APB2總線(16)。

GPIO設備的最大驅動時鐘速率(各個條件已在上述要點中假設):

1) 由3所知晶振輸入為8MHz,由5——21知PLL的時鐘源為經(jīng)過分頻后的外部晶振時鐘,并且此分頻數(shù)為1分頻,因此首先得出PLL的時鐘源為:8MHz / 1 = 8MHz。

2) 由8、9知PLL倍頻數(shù)為9,且將PLL倍頻后的時鐘輸出選擇為系統(tǒng)時鐘,則得出系統(tǒng)時鐘為 8MHz * 9 = 72MHz。

3) 時鐘到達AHB預分頻器,由11知時鐘經(jīng)過AHB預分頻器之后的速率仍為72MHz。

4) 時鐘到達APB2預分頻器,由15經(jīng)過APB2預分頻器后速率仍為72MHz。

5) 時鐘到達APB2總線外設。

因此STM32的APB2總線外設,所能達到的最大速率為72MHz。


接下來從程序的角度分析時鐘樹的設置,程序清單如下:

[cpp]view plaincopy

voidRCC_Configuration(void)

{

ErrorStatusHSEStartUpStatus;(1)

RCC_DeInit();(2)

RCC_HSEConfig(RCC_HSE_ON);(3)

HSEStartUpStatus=RCC_WaitForHSEStartUp();(4)

if(HSEStartUpStatus==SUCCESS)(5)

{

RCC_HCLKConfig(RCC_SYSCLK_Div1);(6)

RCC_PCLK2Config(RCC_HCLK_Div1); (7)

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

在嵌入式開發(fā)中,STM32的時鐘系統(tǒng)因其靈活性和復雜性成為開發(fā)者關注的焦點。然而,看似簡單的時鐘配置背后,隱藏著諸多易被忽視的陷阱,輕則導致系統(tǒng)不穩(wěn)定,重則引發(fā)硬件損壞。本文從時鐘源選擇、PLL配置、總線時鐘分配等關鍵環(huán)...

關鍵字: STM32 時鐘系統(tǒng)

在嵌入式系統(tǒng)開發(fā)中,STM32系列微控制器的內部溫度傳感器因其低成本、高集成度特性,廣泛應用于設備自檢、環(huán)境監(jiān)測等場景。然而,受芯片工藝差異和電源噪聲影響,其原始數(shù)據(jù)存在±1.5℃的固有誤差。本文從硬件配置、校準算法、軟...

關鍵字: STM32 溫度傳感器

在能源效率與智能化需求雙重驅動下,AC-DC轉換器的數(shù)字控制技術正經(jīng)歷從傳統(tǒng)模擬方案向全數(shù)字架構的深刻變革?;赟TM32微控制器的PFM(脈沖頻率調制)+PWM(脈沖寬度調制)混合調制策略,結合動態(tài)電壓調整(Dynam...

關鍵字: AC-DC STM32

當前智能家居產(chǎn)品需求不斷增長 ,在這一背景下 ,對現(xiàn)有澆花裝置缺陷進行了改進 ,設計出基于STM32單片機的全 自動家用澆花機器人。該設計主要由機械結構和控制系統(tǒng)構成 ,機械結構通過麥克納姆輪底盤與噴灑裝置的結合實現(xiàn)機器...

關鍵字: STM32 麥克納姆輪 安全可靠 通過性強

用c++編程似乎是讓你的Arduino項目起步的障礙嗎?您想要一種更直觀的微控制器編程方式嗎?那你需要了解一下Visuino!這個圖形化編程平臺將復雜電子項目的創(chuàng)建變成了拖動和連接塊的簡單任務。在本文中,我們將帶您完成使...

關鍵字: Visuino Arduino ESP32 STM32

基于STM32與LoRa技術的無線傳感網(wǎng)絡憑借其低功耗、廣覆蓋、抗干擾等特性,成為環(huán)境監(jiān)測、工業(yè)自動化等場景的核心解決方案。然而,如何在復雜電磁環(huán)境中實現(xiàn)高效休眠調度與動態(tài)信道優(yōu)化,成為提升網(wǎng)絡能效與可靠性的關鍵挑戰(zhàn)。本...

關鍵字: STM32 LoRa

在實時控制系統(tǒng)、高速通信協(xié)議處理及高精度數(shù)據(jù)采集等對時間敏感的應用場景中,中斷響應延遲的優(yōu)化直接決定了系統(tǒng)的可靠性與性能上限。STM32系列微控制器憑借其靈活的嵌套向量中斷控制器(NVIC)、多通道直接內存訪問(DMA)...

關鍵字: STM32 DMA

數(shù)字電源技術向高功率密度、高效率與高動態(tài)響應方向加速演進,STM32微控制器憑借其基于DSP庫的算法加速能力與對LLC諧振變換器的精準控制架構,成為優(yōu)化電源動態(tài)性能的核心平臺。相較于傳統(tǒng)模擬控制或通用型數(shù)字控制器,STM...

關鍵字: STM32 數(shù)字電源

STM32微控制器憑借其針對電機控制場景的深度優(yōu)化,成為高精度、高可靠性驅動系統(tǒng)的核心選擇。相較于通用型MCU,STM32在電機控制領域的核心優(yōu)勢集中體現(xiàn)在FOC(磁場定向控制)算法的硬件加速引擎與PWM死區(qū)時間的動態(tài)補...

關鍵字: STM32 電機控制

無線充電技術加速滲透消費電子與汽車電子領域,基于Qi協(xié)議的無線充電發(fā)射端開發(fā)成為智能設備能量補給的核心課題。傳統(tǒng)模擬控制方案存在響應滯后、參數(shù)調整困難等問題,而基于STM32的數(shù)字PID控制結合FOD(Foreign O...

關鍵字: STM32 無線充電
關閉