STM32時鐘配置方法

1、在STM32中,有五個時鐘源,爲HSIHSELSILSEPLL緩存

HSI是高速內部時鐘,RC振盪器,頻率爲8MHz函數

HSE是高速外部時鐘,可接石英/陶瓷諧振器,或者接外部時鐘源,頻率範圍爲4MHz~16MHz性能

LSI是低速內部時鐘,RC振盪器,頻率爲40kHzfetch

LSE是低速外部時鐘,接頻率爲32.768kHz的石英晶體。ui

PLL爲鎖相環倍頻輸出,其時鐘輸入源可選擇爲HSI/2HSE或者HSE/2。倍頻可選擇爲2~16倍,可是其輸出頻率最大不得超過72MHzspa

2、在STM32上若是不使用外部晶振,OSC_IN和OSC_OUT的接法:若是使用內部RC振盪器而不使用外部晶振,請按照下面方法處理:.net

對於100腳或144腳的產品,OSC_IN應接地,OSC_OUT應懸空。
對於少於100腳的產品,有2種接法:第1種:OSC_INOSC_OUT分別經過10K電阻接地。此方法可提升EMC性能;第2種:分別重映射OSC_INOSC_OUTPD0PD1,再配置PD0PD1爲推輓輸出並輸出'0'。此方法能夠減少功耗並(相對上面)節省2個外部電阻。
orm

3、用HSE時鐘,程序設置時鐘參數流程
01、將RCC寄存器從新設置爲默認值   RCC_DeInit;
02、打開外部高速時鐘晶振HSE    RCC_HSEConfig(RCC_HSE_ON);
03、等待外部高速時鐘晶振工做    HSEStartUpStatus = RCC_WaitForHSEStartUp();
04、設置AHB時鐘         RCC_HCLKConfig;
05、設置高速AHB時鐘     RCC_PCLK2Config;
06、設置低速速AHB時鐘   RCC_PCLK1Config;
07、設置PLL              RCC_PLLConfig;
08、打開PLL              RCC_PLLCmd(ENABLE);
09、等待PLL工做   while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
10、設置系統時鐘        RCC_SYSCLKConfig;
11、判斷是否PLL是系統時鐘     while(RCC_GetSYSCLKSource() != 0x08)
12、打開要使用的外設時鐘    RCC_APB2PeriphClockCmd()/RCC_APB1PeriphClockCmd()
blog

4、下面是STM32軟件固件庫的程序中對RCC的配置函數(使用外部8MHz晶振)ip

/*******************************************************************************

* Function Name  : RCC_Configuration 

* Description    :  RCC配置(使用外部8MHz晶振)

* Input            : 

* Output         : 

* Return         : 

*******************************************************************************/

void RCC_Configuration(void)

{

  /*將外設RCC寄存器重設爲缺省值*/

  RCC_DeInit();

 

  /*設置外部高速晶振(HSE*/

  RCC_HSEConfig(RCC_HSE_ON);   //RCC_HSE_ON——HSE晶振打開(ON)

 

  /*等待HSE起振*/

  HSEStartUpStatus = RCC_WaitForHSEStartUp();

 

  if(HSEStartUpStatus == SUCCESS)        //SUCCESSHSE晶振穩定且就緒

  {

    /*設置AHB時鐘(HCLK*/ 

    RCC_HCLKConfig(RCC_SYSCLK_Div1);  //RCC_SYSCLK_Div1——AHB時鐘系統時鐘

 

    /* 設置高速AHB時鐘(PCLK2*/ 

    RCC_PCLK2Config(RCC_HCLK_Div1);   //RCC_HCLK_Div1——APB2時鐘= HCLK

 

    /*設置低速AHB時鐘(PCLK1*/    

RCC_PCLK1Config(RCC_HCLK_Div2);   //RCC_HCLK_Div2——APB1時鐘= HCLK / 2

 

    /*設置FLASH存儲器延時時鐘週期數*/

    FLASH_SetLatency(FLASH_Latency_2);    //FLASH_Latency_2  2延時週期

   

 /*選擇FLASH預取指緩存的模式*/  

    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);       // 預取指緩存使能

 

    /*設置PLL時鐘源及倍頻係數*/ 

    RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);     

// PLL的輸入時鐘= HSE時鐘頻率RCC_PLLMul_9——PLL輸入時鐘x 9

   

  /*使能PLL */

    RCC_PLLCmd(ENABLE); 

 

    /*檢查指定的RCC標誌位(PLL準備好標誌)設置與否*/   

    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)      

       {

       }

 

    /*設置系統時鐘(SYSCLK*/ 

    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); 

//RCC_SYSCLKSource_PLLCLK——選擇PLL做爲系統時鐘

 

    /* PLL返回用做系統時鐘的時鐘源*/

    while(RCC_GetSYSCLKSource() != 0x08)        //0x08PLL做爲系統時鐘

       { 

       }

     }

 

 /*使能或者失能APB2外設時鐘*/    

  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | 

RCC_APB2Periph_GPIOC , ENABLE); 

//RCC_APB2Periph_GPIOA    GPIOA時鐘

//RCC_APB2Periph_GPIOB    GPIOB時鐘

//RCC_APB2Periph_GPIOC    GPIOC時鐘

//RCC_APB2Periph_GPIOD    GPIOD時鐘

}

5、時鐘頻率

STM32F103內部8M的內部震盪,通過倍頻後最高能夠達到72M。目前TI的M3系列芯片最高頻率能夠達到80M。

在stm32固件庫3.0中對時鐘頻率的選擇進行了大大的簡化,原先的一大堆操做都在後臺進行。系統給出的函數爲SystemInit()。但在調用前還須要進行一些宏定義的設置,具體的設置在system_stm32f10x.c文件中。

文件開頭就有一個這樣的定義: 
//#define SYSCLK_FREQ_HSE    HSE_Value 
//#define SYSCLK_FREQ_20MHz 20000000 
//#define SYSCLK_FREQ_36MHz 36000000 
//#define SYSCLK_FREQ_48MHz 48000000 
//#define SYSCLK_FREQ_56MHz 56000000 
#define SYSCLK_FREQ_72MHz 72000000

ST 官方推薦的外接晶振是 8M,因此庫函數的設置都是假定你的硬件已經接了 8M 晶振來運算的.以上東西就是默認晶振 8M 的時候,推薦的 CPU 頻率選擇.在這裏選擇了:
#define SYSCLK_FREQ_72MHz 72000000 
也就是103系列能跑到的最大值72M

而後這個 C文件繼續往下看 
#elif defined SYSCLK_FREQ_72MHz 
const uint32_t SystemFrequency         = SYSCLK_FREQ_72MHz;    
const uint32_t SystemFrequency_SysClk = SYSCLK_FREQ_72MHz;    
const uint32_t SystemFrequency_AHBClk = SYSCLK_FREQ_72MHz;    
const uint32_t SystemFrequency_APB1Clk = (SYSCLK_FREQ_72MHz/2);
const uint32_t SystemFrequency_APB2Clk = SYSCLK_FREQ_72MHz;

這就是在定義了CPU跑72M的時候,各個系統的速度了.他們分別是:硬件頻率,系統時鐘,AHB總線頻率,APB1總線頻率,APB2總線頻率.再往下看,看到這個了: 
#elif defined SYSCLK_FREQ_72MHz 
static void SetSysClockTo72(void);

這就是定義 72M 的時候,設置時鐘的函數.這個函數被 SetSysClock ()函數調用,而
SetSysClock ()函數則是被 SystemInit()函數調用.最後 SystemInit()函數,就是被你調用的了

因此設置系統時鐘的流程就是: 
首先用戶程序調用 SystemInit()函數,這是一個庫函數,而後 SystemInit()函數裏面,進行了一些寄存器必要的初始化後,就調用 SetSysClock()函數. SetSysClock()函數根據那個#define SYSCLK_FREQ_72MHz 72000000 的宏定義,知道了要調用SetSysClockTo72()這個函數,因而,就一堆麻煩而複雜的設置~!@#$%^而後,CPU跑起來了,並且速度是 72M. 雖說的有點累贅,但你們只須要知道,用戶要設置頻率,程序中就作的就兩個事情:

第一個: system_stm32f10x.c 中 #define SYSCLK_FREQ_72MHz 72000000 
第二個:調用SystemInit()

轉載自:https://blog.csdn.net/kevinhg/article/details/17517117

相關文章
相關標籤/搜索