新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > STM32時鐘設置

        STM32時鐘設置

        作者: 時間:2016-11-28 來源:網絡 收藏
        3.5的庫中什么也不用做。已經在啟動文件中設置好了時鐘。

        大家都知道在使用單片機時,時鐘速度決定于外部晶振或內部RC振蕩電路的頻率,是不可以改變的。而ARM的出現打破了這一傳統的法則,可以通過軟件隨意改變時鐘速度。這一出現讓我們的設計更加靈活,但是也給我們的設計增加了復雜性。為了讓用戶能夠更簡單的使用這一功能,STM32的庫函數已經為我們設計的更加簡單方便。

        本文引用地址:http://www.104case.com/article/201611/322746.htm

        在比較靠前的版本中,我們需要向下面那樣設置時鐘:

        ErrorStatus HSEStartUpStatus;


        void RCC_Configuration(void)
        {
        RCC_DeInit(); // RCC system reset(for debug purpose)

        RCC_HSEConfig(RCC_HSE_ON);// Enable HSE

        HSEStartUpStatus = RCC_WaitForHSEStartUp();// Wait till HSE is ready

        if (HSEStartUpStatus == SUCCESS)// 當HSE準備完畢切振蕩穩定后
        {
        RCC_HCLKConfig(RCC_SYSCLK_Div1); // HCLK = SYSCLK
        RCC_PCLK2Config(RCC_HCLK_Div1); // PCLK2 = HCLK
        RCC_PCLK1Config(RCC_HCLK_Div2);// PCLK1 = HCLK/2
        FLASH_SetLatency(FLASH_Latency_2);// Flash 2 wait state
        FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);// Enable Prefetch Buffer
        RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);// PLLCLK = 8MHz * 9 = 72 MHz
        RCC_PLLCmd(ENABLE);// Enable PLL
        while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
        {;// Wait till PLL is ready
        }
        RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);// Select PLL as system clock source
        while (RCC_GetSYSCLKSource() != 0x08)// Wait till PLL is used as system clock source
        {
        ;
        }
        }
        }

        隨之函數庫的不斷升級,到3.0以上時,我們就不用再這樣編寫時鐘設置了,我們只要做如下兩部即可:

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

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

        文件開頭就有一個這樣的定義:
        //#define SYSCLK_FREQ_HSEHSE_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.




        關鍵詞: STM32時鐘設

        評論


        技術專區

        關閉
        主站蜘蛛池模板: 印江| 广汉市| 盘锦市| 高州市| 新民市| 诏安县| 孟津县| 株洲县| 达州市| 驻马店市| 苍梧县| 睢宁县| 乡宁县| 广西| 汝州市| 沙雅县| 和龙市| 城市| 建阳市| 临颍县| 离岛区| 大安市| 洪雅县| 策勒县| 宁晋县| 乌兰浩特市| 库车县| 承德市| 新源县| 外汇| 定州市| 景谷| 肃北| 延安市| 萨嘎县| 自贡市| 射阳县| 天祝| 广水市| 嵊泗县| 富宁县|