一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

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

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

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

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

圖片

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

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

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

2.2 時(shí)鐘配置

圖片

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

2.2.1 時(shí)鐘配置流程

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

(2)設(shè)置PLL倍頻系數(shù)為9,因?yàn)橥饨?MHz時(shí)鐘,所以設(shè)置系數(shù)為9就可以輕松達(dá)到8×9=72MHz的時(shí)鐘頻率;

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

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

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

2.2.2 相關(guān)寄存器

(1) 時(shí)鐘控制寄存器 :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準(zhǔn)備狀態(tài)

0:PLL解鎖

          1:PLL鎖定

Bit 24:PLL使能

0:PLL關(guān)閉

          1:PLL打開

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

0:時(shí)鐘保護(hù)關(guān)閉

          1:時(shí)鐘保護(hù)打開

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

0:HSE禁止旁路

          1:HSE打開旁路

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

0:HSE未準(zhǔn)備好

          1:HSE準(zhǔn)備完畢

Bit 16:HSE時(shí)鐘使能

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

          1:HSE時(shí)鐘打開

Bit 15~ Bit 8:HSI校準(zhǔn)值(這個(gè)值在啟動(dòng)的時(shí)候自動(dòng)初始化)

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

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

0:HIS未準(zhǔn)備好

          1:HSI準(zhǔn)備完畢

Bit 0:HSI時(shí)鐘使能

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

          1:HSI時(shí)鐘開啟

(2) 時(shí)鐘配置寄存器 :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:芯片時(shí)鐘輸出

0xx:禁止輸出

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

          101:選擇HSI時(shí)鐘

          110:選擇HSE時(shí)鐘

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

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

0:PLL時(shí)鐘1.5分頻作為USB時(shí)鐘

          1:PLL時(shí)鐘不分頻作為USB時(shí)鐘

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時(shí)鐘選擇(PLL處于禁止模式才能寫入)

0:HSI時(shí)鐘2分頻作為PLL時(shí)鐘輸入

          1:HSE作為PLL時(shí)鐘輸入

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ù)(最高可達(dá)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ù)(最高只能達(dá)到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)時(shí)鐘選擇狀態(tài)

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

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

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

          11:保留

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

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

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

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

          11:保留

2.3 設(shè)置例程

配置STM32的時(shí)鐘需要?jiǎng)?chuàng)建幾個(gè)文件,這幾個(gè)文件如下表所示。

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

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

圖片

圖片

圖片

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

圖片

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

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

圖片

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

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

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

    關(guān)注

    6058

    文章

    44822

    瀏覽量

    644862
  • STM32
    +關(guān)注

    關(guān)注

    2283

    文章

    10986

    瀏覽量

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

    關(guān)注

    9

    文章

    271

    瀏覽量

    59992
收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

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

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

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

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

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

    為什么要了解時(shí)鐘

    layout: posttags: [STM32]comments: true文章目錄layout: posttags: [STM32]comments: true為什么要了解時(shí)鐘?的根標(biāo)準(zhǔn)庫(kù)
    發(fā)表于 08-12 06:13

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

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

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

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

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

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

    STM32F429--RCC時(shí)鐘

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

    STM32F10X-時(shí)鐘詳細(xì)介紹

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

    STM32時(shí)鐘

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

    評(píng)價(jià)時(shí)鐘質(zhì)量的方法

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

    時(shí)鐘設(shè)計(jì)師的 5 個(gè)問(wèn)題

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

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

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

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

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

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

    今天來(lái)聊一聊時(shí)鐘。首先我先講一下我所理解的時(shí)鐘是什么,然后介紹兩種時(shí)鐘樹結(jié)構(gòu)。
    的頭像 發(fā)表于 12-06 15:23 ?2169次閱讀