色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

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

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

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

什么是時鐘樹架構(gòu)

汽車電子技術(shù) ? 來源:滑小稽筆記 ? 作者:電子技術(shù)園地 ? 2023-03-02 09:39 ? 次閱讀

2.1 時鐘樹結(jié)構(gòu)圖

STM32屬于Cortex-M3內(nèi)核的單片機,時鐘結(jié)構(gòu)比之前的51單片機較復(fù)雜的多,根據(jù)數(shù)據(jù)手冊,STM32F103的時鐘結(jié)構(gòu)如下圖所示。

圖片

根據(jù)上圖可以看到,STM32F103系列單片機具有4個時鐘源,內(nèi)部的8MHz時鐘發(fā)生器,外部的晶體振蕩器接口,最高支持16MHz,外部的32.768kHz晶體振蕩器接口和內(nèi)部的40kHz時鐘發(fā)生器,其中32.768kHz和40kHz主要用于內(nèi)部RTC時鐘脈沖,8MHz的晶振通過PLL時鐘倍乘器,將系統(tǒng)總線時鐘提高為72MHz。

   STM32F103系列內(nèi)部具有2條外設(shè)時鐘總線,APB1和APB2,其中APB2的時鐘最高可達72MHz,APB1的時鐘最高可達36MHz,通過配置對應(yīng)的寄存器,就可以將CPU內(nèi)核時鐘提高到最大速度。

   通過最小系統(tǒng)可以看到,我們使用外部高速晶體振蕩器接口,外接8MHz晶振,RTC則是使用32.768kHz晶振,現(xiàn)在我們來通過數(shù)據(jù)手冊來配置對應(yīng)的寄存器位來配置APB2時鐘達到72MHz,APB1時鐘達到36MHz。

2.2 時鐘配置

圖片

上圖是ST公司推出的一款軟件,這款軟件可以自動生成寄存器代碼,但是我們在這里只用到其中提供的時鐘配置功能,通過上面的時鐘結(jié)構(gòu),我們可以得到配置時鐘的大概流程。

2.2.1 時鐘配置流程

(1)開啟HSE時鐘接口,這個接口用于使能晶體振蕩器輸入端;

(2)設(shè)置PLL倍頻系數(shù)為9,因為外接8MHz時鐘,所以設(shè)置系數(shù)為9就可以輕松達到8×9=72MHz的時鐘頻率;

(3)設(shè)置時鐘源為PLLCLK,因為HSE使用的時候可以發(fā)現(xiàn)最終的輸出就是PLL時鐘脈沖;

(4)設(shè)置APB1時鐘總線的分頻系數(shù)為2,因為APB1時鐘總線最高頻率只有36MHz;

(5)設(shè)置APB2時鐘總線的分頻系數(shù)為1。

2.2.2 相關(guān)寄存器

(1) 時鐘控制寄存器 :RCC_CR

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
- PLLRDY PLLON - CSSON HSEBYP HSERDY HSEON
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
HSICAL[7:0] HSITRIM[4:0] - HISRDY HISON

Bit 25:PLL準備狀態(tài)

0:PLL解鎖

          1:PLL鎖定

Bit 24:PLL使能

0:PLL關(guān)閉

          1:PLL打開

Bit 19:時鐘安全系統(tǒng)開關(guān)

0:時鐘保護關(guān)閉

          1:時鐘保護打開

Bit 18:HSE旁路(禁用HSE振蕩器時才能寫入)

0:HSE禁止旁路

          1:HSE打開旁路

Bit 17:HSE準備狀態(tài)

0:HSE未準備好

          1:HSE準備完畢

Bit 16:HSE時鐘使能

0:HSE時鐘關(guān)閉

          1:HSE時鐘打開

Bit 15~ Bit 8:HSI校準值(這個值在啟動的時候自動初始化)

Bit 7~ Bit 3:HSI微調(diào)(對其進行編程以適應(yīng)電壓和溫度的變化影響內(nèi)部HSI的頻率。初始值16,步長約為40kHz)

Bit 1:HSI準備狀態(tài)

0:HIS未準備好

          1:HSI準備完畢

Bit 0:HSI時鐘使能

0:HIS時鐘關(guān)閉

          1:HSI時鐘開啟

(2) 時鐘配置寄存器 :RCC_CFGR

31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16
- MCO[2:0] - USBPRE PLLMUL[3:0] PLLXTPRE PLLSRC
15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
ADCPRE[1:0] PPRE2[2:0] PPRE1[2:0] HPRE[3:0] SWS[1:0] SW[1:0]

Bit 26~Bit 24:芯片時鐘輸出

0xx:禁止輸出

          100:選擇系統(tǒng)時鐘SYSCLK

          101:選擇HSI時鐘

          110:選擇HSE時鐘

          111:選擇PLL分頻輸出(2分頻)

Bit 22:USB時鐘分頻系數(shù)

0:PLL時鐘1.5分頻作為USB時鐘

          1:PLL時鐘不分頻作為USB時鐘

Bit 21~Bit 18:PLL倍頻系數(shù)

0000:2倍頻

          0001:3倍頻

          0010:4倍頻

          0011:5倍頻

          0100:6倍頻

          0101:7倍頻

          0110:8倍頻

          0111:9倍頻

          1000:10倍頻

          1001:11倍頻

          1010:12倍頻

          1011:13倍頻

          1100:14倍頻

          1101:15倍頻

          1110:16倍頻

          1111:16倍頻

Bit 17:HSE輸入分頻器

0:HSE輸入不分頻

          1:HSE輸入2分頻

Bit 16:PLL時鐘選擇(PLL處于禁止模式才能寫入)

0:HSI時鐘2分頻作為PLL時鐘輸入

          1:HSE作為PLL時鐘輸入

Bit 15~Bit 14:ADC分頻系數(shù)

00:PCLK2分頻系數(shù)為2

          01:PCLK2分頻系數(shù)為4

          10:PCLK2分頻系數(shù)為6

          11:PCLK2分頻系數(shù)為8

Bit 13~Bit 11:APB2分頻系數(shù)(最高可達72MHz)

0xx:HCLK不分頻

          100:HCLK分頻系數(shù)為2

          101:HCLK分頻系數(shù)為4

          110:HCLK分頻系數(shù)為8

          111:HCLK分頻系數(shù)為16

Bit 10~Bit 8:APB1分頻系數(shù)(最高只能達到36MHz)

0xx:HCLK不分頻

          100:HCLK分頻系數(shù)為2

          101:HCLK分頻系數(shù)為4

          110:HCLK分頻系數(shù)為8

          111:HCLK分頻系數(shù)為16

Bit 7~Bit 4:AHB總線預(yù)分頻系數(shù)

0xxx:SYSCLK不分頻

          1000:SYSCLK分頻系數(shù)為2

          1001:SYSCLK分頻系數(shù)為4

          1010:SYSCLK分頻系數(shù)為8

          1011:SYSCLK分頻系數(shù)為16

          1100:SYSCLK分頻系數(shù)為64

          1101:SYSCLK分頻系數(shù)為128

          1110:SYSCLK分頻系數(shù)為256

          1111:SYSCLK分頻系數(shù)為512

Bit 3~Bit 2:系統(tǒng)時鐘選擇狀態(tài)

00:HSI作為系統(tǒng)時鐘

          01:HSE作為系統(tǒng)時鐘

          10:PLL作為系統(tǒng)時鐘

          11:保留

Bit 1~Bit 0:系統(tǒng)時鐘選擇

00:選擇HSI作為系統(tǒng)時鐘

          01:選擇HSE作為系統(tǒng)時鐘

          10:選擇PLL作為系統(tǒng)時鐘

          11:保留

2.3 設(shè)置例程

配置STM32的時鐘需要創(chuàng)建幾個文件,這幾個文件如下表所示。

文件目錄 文件名 文件功能
./SYSTEM/sys sys.c 時鐘設(shè)置函數(shù)外部中斷設(shè)置函數(shù)中斷優(yōu)先級設(shè)置函數(shù)
sys.h 數(shù)據(jù)類型定義
stm32f103x.h 定義寄存器結(jié)構(gòu)定義寄存器地址定義中斷編號

(1)創(chuàng)建上述三個文件,其中c文件添加進工程中,h文件包含進程序中,如下圖所示。

圖片

圖片

圖片

(2)stm32f103x.h文件輸入以下內(nèi)容:

圖片

這個文件用于定義程序用到的所有寄存器的地址和結(jié)構(gòu)體,是整個STM32程序的最基礎(chǔ)的文件。

(3)sys.h輸入以下內(nèi)容

圖片

sys.h文件用于定義STM32的時鐘配置和中斷配置,以及后面的端口位操作模式。

(3)sys.c文件輸入以下內(nèi)容

void STM32_Clock_Init( u8 PLL )
{
   RCC->CR |= 0x00010000 ;              //外部高速時鐘使能HSEON
  while( !( RCC->CR>>17 ) ) ;              //等待外部時鐘就緒
  RCC->CFGR = 0x00000400 ;            //APB1=DIV2;APB2=DIV1;AHB=DIV1;
  PLL -= 2 ;                    //抵消2個單位(因為是從2開始的,設(shè)置0就是2)
  RCC->CFGR |= ( u32 )PLL<<18 ;            //設(shè)置PLL值 2~16
  RCC->CFGR |= 1<<16 ;              //PLLSRC ON
  FLASH->ACR |= 0x32 ;                //FLASH 2個延時周期
  RCC->CR |= 1<<24 ;                //PLLON
  while( ( RCC->CR&0x02000000 )!=0x02000000 ) ;    //等待PLL鎖定
  RCC->CFGR |= 0x00000002 ;            //PLL作為系統(tǒng)時鐘
  while( ( RCC->CFGR&0x0000000C )!=0x00000008 ) ;  //等待PLL作為系統(tǒng)時鐘設(shè)置成功
}
這個文件的函數(shù)就是真正配置時鐘的過程,可以對照之前描述的配置時鐘的過程來看這段代碼。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 單片機
    +關(guān)注

    關(guān)注

    6037

    文章

    44561

    瀏覽量

    635571
  • STM32
    +關(guān)注

    關(guān)注

    2270

    文章

    10901

    瀏覽量

    356194
  • Cortex-M3
    +關(guān)注

    關(guān)注

    9

    文章

    270

    瀏覽量

    59487
收藏 人收藏

    評論

    相關(guān)推薦

    時鐘優(yōu)化與有用時鐘延遲

    時鐘優(yōu)化與有用時鐘延遲在 “后端時序修正基本思路” 提到了時序優(yōu)化的基本步驟。其中,最關(guān)鍵的階段就是時鐘建立。
    發(fā)表于 10-26 09:29 ?4430次閱讀
    <b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>優(yōu)化與有用<b class='flag-5'>時鐘</b>延遲

    數(shù)字IC設(shè)計中的分段時鐘綜合

    為什么需要分段去做時鐘呢?因為在某些情況下,按照傳統(tǒng)的方法讓每一個clock group單獨去balance,如果不做額外干預(yù),時鐘天然是做不平的。
    的頭像 發(fā)表于 12-04 14:42 ?2127次閱讀
    數(shù)字IC設(shè)計中的分段<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>綜合

    介紹時鐘的構(gòu)成

    RCC是reset clock control的簡稱(即復(fù)位和時鐘控制器),本文將詳細介紹時鐘的構(gòu)成,通過理解時鐘我們可以更加的理解ST
    發(fā)表于 08-12 07:48

    為什么要了解時鐘

    layout: posttags: [STM32]comments: true文章目錄layout: posttags: [STM32]comments: true為什么要了解時鐘的根標準庫
    發(fā)表于 08-12 06:13

    時鐘網(wǎng)格與時鐘設(shè)計方法對比研究

    基于片上偏差對芯片性能的影響,分析對比了時鐘設(shè)計與時鐘網(wǎng)格設(shè)計,重點分析了時鐘網(wǎng)格抗OCV影響的優(yōu)點,并利用實際電路應(yīng)用兩種方法分別進行設(shè)計對比,通過結(jié)果分析,驗證
    發(fā)表于 05-07 14:13 ?36次下載
    <b class='flag-5'>時鐘</b>網(wǎng)格與<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>設(shè)計方法對比研究

    LUCT工具主要特性及不確定性時鐘設(shè)計方法和算法的介紹

    頂層的根時鐘網(wǎng)絡(luò)(通常是 PLL 輸出)到中層時鐘網(wǎng)絡(luò),LUCT 是一個高質(zhì)量的負載均衡的時鐘,其目標是將時鐘信號從中央鎖相環(huán) PLL 送
    發(fā)表于 11-29 10:58 ?6次下載
    LUCT工具主要特性及不確定性<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>設(shè)計方法和算法的介紹

    STM32時鐘系統(tǒng)時鐘時鐘配置函數(shù)介紹及系統(tǒng)時鐘設(shè)置步驟資料

    本文檔的主要內(nèi)容詳細介紹的是STM32時鐘系統(tǒng)時鐘時鐘配置函數(shù)介紹及系統(tǒng)時鐘設(shè)置步驟資料。
    發(fā)表于 10-11 08:00 ?22次下載
    STM32<b class='flag-5'>時鐘</b>系統(tǒng)<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>和<b class='flag-5'>時鐘</b>配置函數(shù)介紹及系統(tǒng)<b class='flag-5'>時鐘</b>設(shè)置步驟資料

    STM32F429--RCC時鐘

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

    STM32F10X-時鐘詳細介紹

    RCC是reset clock control的簡稱(即復(fù)位和時鐘控制器),本文將詳細介紹時鐘的構(gòu)成,通過理解時鐘我們可以更加的理解ST
    發(fā)表于 12-01 14:36 ?9次下載
    STM32F10X-<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>詳細介紹

    STM32時鐘

    STM32時鐘問題1:為什么需要時鐘?答:STM 32的時鐘系統(tǒng)類似于人的心臟,需要為芯片提供時鐘芯片才能正常工作,而STM32有很多的外
    發(fā)表于 12-06 09:51 ?16次下載
    STM32<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>

    評價時鐘質(zhì)量的方法

    時鐘綜合,通常我們也叫做CTS。時鐘綜合就是建立一個時鐘網(wǎng)絡(luò),使時鐘信號能夠傳遞到各個時序器
    的頭像 發(fā)表于 09-05 10:11 ?1909次閱讀

    時鐘設(shè)計師的 5 個問題

    時鐘設(shè)計師的 5 個問題
    的頭像 發(fā)表于 01-04 11:17 ?916次閱讀
    <b class='flag-5'>時鐘</b><b class='flag-5'>樹</b>設(shè)計師的 5 個問題

    STM32入門學(xué)習筆記之時鐘架構(gòu)(上)

    STM32屬于Cortex-M3內(nèi)核的單片機,時鐘結(jié)構(gòu)比之前的51單片機較復(fù)雜的多,根據(jù)數(shù)據(jù)手冊,STM32F103的時鐘結(jié)構(gòu)
    的頭像 發(fā)表于 02-16 09:49 ?1161次閱讀
    STM32入門學(xué)習筆記之<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b><b class='flag-5'>架構(gòu)</b>(上)

    STM32入門學(xué)習筆記之時鐘架構(gòu)(下)

    STM32屬于Cortex-M3內(nèi)核的單片機,時鐘結(jié)構(gòu)比之前的51單片機較復(fù)雜的多,根據(jù)數(shù)據(jù)手冊,STM32F103的時鐘結(jié)構(gòu)
    的頭像 發(fā)表于 02-16 09:49 ?807次閱讀
    STM32入門學(xué)習筆記之<b class='flag-5'>時鐘</b><b class='flag-5'>樹</b><b class='flag-5'>架構(gòu)</b>(下)

    時鐘是什么?介紹兩種時鐘樹結(jié)構(gòu)

    今天來聊一聊時鐘。首先我先講一下我所理解的時鐘是什么,然后介紹兩種時鐘樹結(jié)構(gòu)。
    的頭像 發(fā)表于 12-06 15:23 ?1756次閱讀
    主站蜘蛛池模板: 综合网伊人| 干极品美女| 欧美丰满少妇久久无码精品| 成人永久免费视频| 45分钟做受片免费观看| 亚洲国产成人久久精品影视| 欧美jizz19性欧美| 久久精品国产久精国产果冻传媒| 超碰在线视频地址| 99re8在线视频精品| 有人在线观看的视频吗免费| 午夜伦理 第1页| 少妇精油按摩| 入禽太深免费视频10| 日日射日日操| 色欲天天婬色婬香影院| 日日干夜夜啪蕉视频| 日本人吃奶玩奶虐乳| 欧美最新色p图| 日韩精品久久日日躁夜夜躁影视| 欧美人与动牲交A免费| 入禽太深免费视频10| 无码日本亚洲一区久久精品 | 丰满少妇69激懒啪啪无码| 操他射他影院| 国产婷婷色一区二区三区在线| 国产精品无需播放器| 国产精品久久久久久久久免费下载| 国产精品久久久久久免费播放| 国产精品一区二区20P| 久久精品av| 日韩视频中文字幕精品偷拍| 午夜福利试看120秒体验区| 亚洲欧美视频在线| 777米奇色狠狠俺去啦| 国产av久久免费观看| 久久久精品久久久久久| 色欲AV亚洲永久无码精品| 亚洲色欲国产免费视频| jj插入bb| 久久是热频国产在线|