STM32時(shí)鐘設置
大家都知道在使用單片機時(shí),時(shí)鐘速度決定于外部晶振或內部RC振蕩電路的頻率,是不可以改變的。而ARM的出現打破了這一傳統的法則,可以通過(guò)軟件隨意改變時(shí)鐘速度。這一出現讓我們的設計更加靈活,但是也給我們的設計增加了復雜性。為了讓用戶(hù)能夠更簡(jiǎn)單的使用這一功能,STM32的庫函數已經(jīng)為我們設計的更加簡(jiǎn)單方便。
本文引用地址:http://dyxdggzs.com/article/201611/322746.htmErrorStatus HSEStartUpStatus;
void RCC_Configuration(void)
{
RCC_HSEConfig(RCC_HSE_ON);
HSEStartUpStatus = RCC_WaitForHSEStartUp();
}
隨之函數庫的不斷升級,到3.0以上時(shí),我們就不用再這樣編寫(xiě)時(shí)鐘設置了,我們只要做如下兩部即可:
第一個(gè): system_stm32f10x.c 中#define SYSCLK_FREQ_72MHz 72000000
第二個(gè):調用SystemInit()
說(shuō)明:在stm32固件庫3.0中對時(shí)鐘頻率的選擇進(jìn)行了大大的簡(jiǎn)化,原先的一大堆操作都在后臺進(jìn)行。系統給出的函數為SystemInit()。但在調用前還需要進(jìn)行一些宏定義的設置,具體的設置在system_stm32f10x.c文件中。
文件開(kāi)頭就有一個(gè)這樣的定義:
//#define SYSCLK_FREQ_HSE
//#define SYSCLK_FREQ_20MHz 20000000
//#define SYSCLK_FREQ_36MHz 36000000
//#define SYSCLK_FREQ_48MHz 48000000
//#define SYSCLK_FREQ_56MHz 56000000
也就是103系列能跑到的最大值72M
然后這個(gè) C文件繼續往下看
#elif defined SYSCLK_FREQ_72MHz
const uint32_t SystemFrequency
const uint32_t SystemFrequency_SysClk
const uint32_t SystemFrequency_AHBClk
const uint32_t SystemFrequency_APB1Clk
const uint32_t SystemFrequency_APB2Clk
#elif defined SYSCLK_FREQ_72MHz
static void SetSysClockTo72(void);
所以設置系統時(shí)鐘的流程就是: 首先用戶(hù)程序調用 SystemInit()函數,這是一個(gè)庫函數,然后 SystemInit()函數里面,進(jìn)行了一些寄存器必要的初始化后,就調用 SetSysClock()函數. SetSysClock()函數根據那個(gè)#define SYSCLK_FREQ_72MHz 72000000 的宏定義,知道了要調用SetSysClockTo72()這個(gè)函數,于是,就一堆麻煩而復雜的設置~!@#$%^然后,CPU跑起來(lái)了,而且速度是 72M.
評論