在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

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

3天內不再提示

深度剖析STM32時鐘系統

NJ90_gh_bee81f8 ? 2017-12-22 09:56 ? 次閱讀

下圖是STM32時鐘樹。從樹上我們可以看到,STM32的時鐘有兩個來源——內部時鐘和外部時鐘。按時鐘頻率來分,又分為高速時鐘和低速時鐘。所以STM32的時鐘有四個來源——高速外部時鐘信號(HSE)、低速外部時鐘信號(LSE)、高速內部時鐘信號(HSI)和低速內部時鐘信號(LSI),圖中分別用藍色的①~④標注。
深度剖析STM32時鐘系統

①HSE高速外部時鐘:由外部4~16MHz的晶體或有源晶振提供,通常采用8MHz,ST三合一板上的也是8MHz。

②LSI低速外部時鐘:外部晶體提供,主要是給實時時鐘(RTC),一般為32.768kHz。

③HSI高速內部時鐘:由內部RC振蕩器產生的8MHz時鐘,但不夠穩定。

④LSI低速內部時鐘:內部RC振蕩器產生的供給RTC的時鐘,頻率在30kHz~60kHz之間,通常約40kHz。

時鐘在STM32內部最終是供給四大塊,圖中用紅色橢圓圈出——USB的48MHz時鐘、系統時鐘SYSCLK、實時時鐘模塊RTC、獨立看門狗的時鐘IWDGCLK。其中最主要的,也是最大頭是系統時鐘SYSCLK,它可以是內部或外部高速時鐘直接接過來,也可以內、外部高速時鐘是PLL倍頻后提供的,系統時鐘再分別供給Cortex內核、SDIO、AHB總線、DMA、APB1、APB2等。

我們通常是采用外部8MHz高速時鐘(HSE),所以著重說HSE。我們以前面的GPIO上的時鐘為例,由ST的Datasheet可知,GPIO是在APB2高速外設總線上的,圖中綠色的線就是時鐘的流程,我們一步步地來看。

8MHz外部晶體(或晶振)輸入后,先經過一個開關PLLXTPRE(HSE divider for PLL entry),此開關決定對HSE進行2分頻再輸入到PLL或直接到PLL。我們選擇不分頻。

這樣時鐘又到了第二個開關PLLSRC(PLL entry clock source),此開關決定PLL的時鐘來源,是內部高速時鐘二分頻的時鐘還是PLLXTPRE的輸出。我們選擇后者,這時的時鐘在進入PLL前還是8MHz,因為在PLLXTPRE我們沒有分頻。

到了PLL倍頻器,由PLLMUL決定倍頻系統數,可以選擇2~16倍頻輸出,但記住,PLL輸出頻率最高72MHz,所以我們選擇9倍頻,這樣PLL輸出就是最高72MHz的PLLCLK時鐘了。這時的PLLCLK為USB提供時鐘。

開關SW來決定SYSCLK的時鐘來源,前面已經提到,這里我們由PLLCLK做為SYSCLK的來源,這樣系統時鐘SYSCLK就是72MHz了。

在供給外設前,先經過AHB預分頻,我們選擇不分頻;在供給GPIO前,還要再經過APB2預分頻,因為APB2為高速外設,所以我們選擇不分頻,這樣GPIO的時鐘就是72MHz了。注意,低速外設APB1最高頻率為36MHz,所以在使用APB1的外設時,要注意設置好分頻系統。還要注意,要使用外設,先要對外設時鐘進行使能,見圖中黃色云形框。這是因為STM32采用了低功耗的設計,對不使用的外設,其時鐘不使能,以達到降低功耗的效果。

時鐘的設置在程序中是怎么來實現的呢?這里我們以前面GPIO的程序來一步步分析。當然,前面的程序是基于ST庫的,其實也就是分析ST的官方庫了。

我們看到main()函數中的第一行代碼是調用了一個函數:

SystemInit();

這個函數是在system_stm32f10x.c中:

void SystemInit (void)

{

/* Reset the RCC clock configuration to the default reset state(for debug purpose) */

/* Set HSION bit */

RCC->CR |= (uint32_t)0x00000001;

/* Reset SW, HPRE, PPRE1, PPRE2, ADCPRE and MCO bits */

#ifndef STM32F10X_CL

RCC->CFGR &= (uint32_t)0xF8FF0000;

#else

RCC->CFGR &= (uint32_t)0xF0FF0000;

#endif /* STM32F10X_CL */

/* Reset HSEON, CSSON and PLLON bits */

RCC->CR &= (uint32_t)0xFEF6FFFF;

/* Reset HSEBYP bit */

RCC->CR &= (uint32_t)0xFFFBFFFF;

/* Reset PLLSRC, PLLXTPRE, PLLMUL and USBPRE/OTGFSPRE bits */

RCC->CFGR &= (uint32_t)0xFF80FFFF;

#ifdef STM32F10X_CL

/* Reset PLL2ON and PLL3ON bits */

RCC->CR &= (uint32_t)0xEBFFFFFF;

/* Disable all interrupts and clear pending bits */

RCC->CIR = 0x00FF0000;

/* Reset CFGR2 register */

RCC->CFGR2 = 0x00000000;

#elif defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || (defined STM32F10X_HD_VL)

/* Disable all interrupts and clear pending bits */

RCC->CIR = 0x009F0000;

/* Reset CFGR2 register */

RCC->CFGR2 = 0x00000000;

#else

/* Disable all interrupts and clear pending bits */

RCC->CIR = 0x009F0000;

#endif /* STM32F10X_CL */

#if defined (STM32F10X_HD) || (defined STM32F10X_XL) || (defined STM32F10X_HD_VL)

#ifdef DATA_IN_ExtSRAM

SystemInit_ExtMemCtl();

#endif /* DATA_IN_ExtSRAM */

#endif

/* Configure the System clock frequency, HCLK, PCLK2 and PCLK1 prescalers */

/* Configure the Flash Latency cycles and enable prefetch buffer */

SetSysClock();

#ifdef VECT_TAB_SRAM

SCB->VTOR = SRAM_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM. */

#else

SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH. */

#endif

}

我們可以看到,程序前面一系統Reset或Disable,最后調用了(紅色標記出來)

SetSysClock();

SetSysClock()函數也位于system_stm32f10x.c源文件中:

static void SetSysClock(void)

{

#ifdef SYSCLK_FREQ_HSE

SetSysClockToHSE();

#elif defined SYSCLK_FREQ_24MHz

SetSysClockTo24();

#elif defined SYSCLK_FREQ_36MHz

SetSysClockTo36();

#elif defined SYSCLK_FREQ_48MHz

SetSysClockTo48();

#elif defined SYSCLK_FREQ_56MHz

SetSysClockTo56();

#elif defined SYSCLK_FREQ_72MHz

SetSysClockTo72();

#endif

/* If none of the define above is enabled, the HSI is used as System clock

source (default after reset) */

}

因為我們使用的是72MHz時鐘,那肯定我們定義了宏SYSCLK_FREQ_72MHz,所以才調用的函數SetSysClockTo72()。我們繼續跟蹤,會發現在源文件開頭,我們的確定義了:

#define SYSCLK_FREQ_72MHz 72000000

在SetSysClockTo72()函數中詳細地對72MHz進行設置,這里就不一步步分析。

前面已經提到,在使用外設時,要使能相應的外設時鐘,例如,在使用GPIOB進行流水燈實驗時,程序中調用了下面的庫函數,對外設時鐘進行設置:

RCC_APB2PeriphClockCmd( RCC_APB2Periph_GPIOB, ENABLE);

另外,STM32還可以把時鐘輸出,如圖左下角的咖啡色方框里面,可以由MCO決定,PLL時鐘二分頻或HIS或HSE或系統時鐘作為主時鐘輸出。


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2270

    文章

    10900

    瀏覽量

    356057
  • 時鐘系統
    +關注

    關注

    1

    文章

    101

    瀏覽量

    11723

原文標題:STM32學習-時鐘系統

文章出處:【微信號:gh_bee81f890fc1,微信公眾號:面包板社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    《C語言深度剖析》【超經典書籍】

    本帖最后由 zgzzlt 于 2012-8-16 14:23 編輯 《C語言深度剖析》【超經典書籍】
    發表于 08-02 08:59

    C語言深度剖析

    C語言深度剖析——一本關于C語言學習的教程,里面包含C語言編寫規范,各種變量指針用法等。以含金量勇敢挑戰國內外同類書籍
    發表于 08-14 11:36

    c語言深度剖析

    c語言深度剖析
    發表于 04-02 09:12

    陳正沖《C語言深度剖析

    陳正沖編寫的《C語言深度剖析》,挺經典,剛來論壇,多多指教~~
    發表于 08-17 12:06

    【資料分享】C語言深度剖析

    C語言深度剖析
    發表于 10-16 15:16

    C語言深度剖析

    C語言深度剖析
    發表于 08-25 09:08

    C語言深度剖析

    C語言深度剖析[完整版].pdfC語言深度剖析[完整版].pdf (919.58 KB )
    發表于 03-19 05:11

    C語言深度剖析

    C語言深度剖析
    發表于 05-05 17:40 ?7次下載

    STM32系統時鐘框架圖

    STM32系統時鐘框架圖,能夠幫你詳細了解STM32單片機時鐘
    發表于 08-18 18:24 ?19次下載

    C語言深度剖析

    C語言深度剖析
    發表于 12-20 22:50 ?0次下載

    《嵌入式 - 深入剖析STM32》詳解STM32時鐘系統

    ,才能夠做其他的處理 (點燈,串口,ADC),時鐘的重要性不言而喻。為什么 STM32 要有多個時鐘源呢?我們在學習51單片機時,其最小系統必有晶振電路,這塊電路就是單片機的
    發表于 11-22 19:36 ?10次下載
    《嵌入式 - 深入<b class='flag-5'>剖析</b><b class='flag-5'>STM32</b>》詳解<b class='flag-5'>STM32</b><b class='flag-5'>時鐘</b><b class='flag-5'>系統</b>

    STM32STM32F4時鐘系統

    00. 目錄文章目錄00. 目錄01. STM32F4時鐘系統概述02. STM32F4時鐘系統
    發表于 11-25 20:06 ?46次下載
    【<b class='flag-5'>STM32</b>】<b class='flag-5'>STM32</b>F4<b class='flag-5'>時鐘</b><b class='flag-5'>系統</b>

    stm32學習筆記-時鐘系統

    IWDG獨立看門狗時鐘四、MCO時鐘輸出五、stm32時鐘系統的編程5.1 系統啟動文件的默認
    發表于 12-01 14:36 ?10次下載
    <b class='flag-5'>stm32</b>學習筆記-<b class='flag-5'>時鐘</b><b class='flag-5'>系統</b>

    STM32時鐘系統時鐘啟動順序詳解

    STM32時鐘系統基本一致,不同系列之間有細微差別。此文檔主要針對STM32F446的時鐘系統
    發表于 02-09 10:31 ?6次下載
    <b class='flag-5'>STM32</b><b class='flag-5'>時鐘</b><b class='flag-5'>系統</b>與<b class='flag-5'>時鐘</b>啟動順序詳解

    C語言深度剖析.zip

    C語言深度剖析
    發表于 12-30 09:20 ?5次下載
    主站蜘蛛池模板: 一个人看的www片免费高清视频| 羞羞爱爱| 色狠狠一区二区| 国产乱辈通伦影片在线播放| 日干夜干天天干| 天天干夜夜玩| 青草国内精品视频在线观看| 亚洲第一视频| 中文字幕亚洲一区二区三区| 色综合久| 综合网视频| 99pao强力打造免费高清色| 色网站免费| 夜色福利| 污污的网站免费阅读| 欧美三级在线免费观看| 天天操国产| 99久久99这里只有免费费精品| 美女免费观看一区二区三区| 久久久久久久影院| 一级@片| 国产大乳孕妇喷奶水在线观看| 国产1卡2卡三卡四卡网站| 欧美三级视频网站| 久久夜夜视频| 性视频网| 午夜影视在线| 好硬好湿好爽再深一点h| 国产网站免费看| 黄h网站| 免费看一级大片| 国内黄色录像| 五月天婷婷色| 午夜精品久久久久久久| 国产免费亚洲| 丁香花五月天婷婷| 亚洲免费区| 国产一卡2卡3卡四卡精品网站| 男人操女人免费网站| 欧美xxxxx喷潮| 1024手机在线看|