STM32入門-STM32時鍾系統,時鍾初始化配置函數


  在前面推文的介紹中,我們知道STM32系統復位后首先進入SystemInit函數進行時鍾的設置,然后進入主函數main。那么我們就來看下SystemInit()函數到底做了哪些操作,首先打開我們前面使用庫函數編寫的LED程序,在system_stm32f10x.c文件中可以找到SystemInit()函數,SystemInit()代碼如下:

  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

  }

  SystemInit函數開始通過條件編譯, 先復位RCC寄存器,同時通過設置CR寄存器的HSI時鍾使能位來打開HSI時鍾。默認情況下如果CR寄存器復位,是選擇HSI作為系統時鍾,這點大家可以查看RCC->CR寄存器相關位描述可以得知,當低兩位配置為00的時候(復位之后),會選擇HSI振盪器為系統時鍾。也就是說,調用SystemInit函數之后,首先是選擇HSI作為系統時鍾。在設置完相關寄存器后才換成HSE作為系統時鍾,接下來SystemInit函數內部會調用SetSysClock()函數。這個函數內部是根據宏定義設置系統時鍾頻率。函數如下:

  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

  }

  在system_stm32f10x.c文件的開頭就有對此宏定義,系統默認的宏定義是72MHz,如下:

  #define SYSCLK_FREQ_72MHz 72000000

  如果你要設置為36MHz,只需要注釋掉上面代碼,然后加入下面代碼即可:

  #define SYSCLK_FREQ_36MHz 36000000

  根據該函數內部實現過程可知,直接調用SetSysClockTo72()函數,此函數功能是將系統時鍾SYSCLK設置為72M,AHB總線時鍾設置為72M,APB2總線時鍾設置為72M,APB1總線時鍾設置為36M,PLL時鍾設置為72M。函數具體實現大家可以打開庫函數查看,這里我們就不截取出來。如果SystemInit內實現過程看不懂沒有關系,大家只要知道SystemInit函數執行完,時鍾大小設置如下:

  SYSCLK(系統時鍾) =72MHz

  AHB 總線時鍾(HCLK=SYSCLK) =72MHz

  APB1 總線時鍾(PCLK1=SYSCLK/2) =36MHz

  APB2 總線時鍾(PCLK2=SYSCLK/1) =72MHz

  PLL 主時鍾 =72MHz

  在STM32中,這些時鍾值是要熟悉的。

最后還是給大家提供一些stm32方面的資料以供后續的學習參考

從0到1,設計自己的開發板

http://www.makeru.com.cn/live/4034_2016.html?s=45051

1小時徹底掌握STM32中斷

http://www.makeru.com.cn/live/3523_1666.html?s=45051

(定時器)

http://www.makeru.com.cn/live/1392_1199.html?s=45051

STM32定時器深藏不露的絕技

http://www.makeru.com.cn/live/3523_1495.html?s=45051

stm32 如何用DMA搬運數據

http://www.makeru.com.cn/live/detail/1484.html?s=45051


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM