STM32系統(tǒng)初始化函數(shù)
keil是兩家私人公司聯(lián)合運營,美國和德國
2005年被ARM公司收購,所有他對ARM內核支持應該是很棒的
ARM為stm32的芯片內核方案,所以keil對stm的芯片支持也很到位
STM32F10x_StdPeriph_Lib_V3.5.0
這個是ST公司專門為10x系列提供的軟件開發(fā)固件庫
首先打開KEIL軟件,當前用的是v4.10
建立好工程后,點擊魔術棒工具 options for target
在C/C++選項,在符號預處理器里定義三個符號
USE_STDPERIPH_DRIVER, 允許使用標準外設驅動 ------------------基本不變
STM32F10X_CL, 主芯片為互聯(lián)網(wǎng)型芯片,105或107-----------根據(jù)芯片改變
USE_STM3210C_EVAL 用的開發(fā)板是STM3210C--------------官方開發(fā)板才用
這樣當編譯工程后,軟件就自動根據(jù)芯片選擇性導入startup_stm32f10x_cl.s這個文件。
這個啟動文件是官方提供的,用匯編語言寫的。
在文件的156行寫了通過這個文件調用systeminit()這個函數(shù)
這個函數(shù)在工程的CMSIS組下的system_stm32f10x.c文件里
文件里一共有兩個函數(shù)systeminit 和 SystemCoreClockUpdate 后者是改變內核時鐘時候才用。
下面是重點了(講了systeminit這個函數(shù)是如何定義時鐘,以及他定義了哪些時鐘)
打開system_stm32f10x.c這個文件,他的代碼解釋如下:
首先是一個芯片選擇定義,如果選擇定義了CL級別芯片,
則預定義 系統(tǒng)時鐘頻率=72M
#define SYSCLK_FREQ_72MHz 72000000
然后問是否定義了外接SRAM
一般都沒有外接(這句就可忽略了)
然后就是定義矢量表偏移 0x0
如果前面定義了外接SRAM就要偏移0X200
接著定義了一個數(shù)組__I uint8_t AHBPrescTable[16] = {0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 6, 7, 8, 9};
這個數(shù)組只在SystemCoreClockUpdate這個函數(shù)里用,重設系統(tǒng)內核時鐘函數(shù),這里是不用的,不看也可以
這個數(shù)組是AHB預分頻器選擇的9種可能,在RCC_CFGR的4~7位
把他的值列出來就發(fā)現(xiàn)一共有16個只,其中前八個的值都表示不分頻,既數(shù)組的前8個0
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
RCC_CFGR 7:4 這就是AHB預分頻器配置
0xxx:SYSCLK 不分頻
1000:SYSCLK 2分頻 1100:SYSCLK 64分頻
1001:SYSCLK 4分頻 1101:SYSCLK 128分頻
1010:SYSCLK 8分頻 1110:SYSCLK 256分頻
1011:SYSCLK 16分頻 1111:SYSCLK 512分頻
下面就是函數(shù)systeminit
1 使能HSI
2 復位RCC_CFGR
3 復位RCC_CR
4 復位RCC_CIR
5 調用SetSysClock(); 設置系統(tǒng)時鐘
根據(jù)芯片選擇函數(shù)SetSysClockTo72();------------------//這個根據(jù)不同芯片是不同的
6 運行函數(shù)SetSysClockTo72();
6.1 使能HSE
6.2 判斷外部時鐘是否已經(jīng)穩(wěn)定運行,穩(wěn)定后就繼續(xù)進行
6.3 外部flash內存使能,并配置相關參數(shù)(這里的外部是內核外部,他還是在芯片內)
在官方參考手冊的3.3.3嵌入式閃存里介紹
7 設置HCLK等于系統(tǒng)時鐘
8 設置PCLK2等于HCLK
9 設置PCLK1等于HCLK
10 設置PLL2輸出時鐘
設置PREDIV1輸出時鐘
11 使能PLL2
12 設置PLL時鐘頻率
13 使能PLL
14 選擇PLL作為系統(tǒng)時鐘源
所以說systeminit函數(shù)其實是定義了時鐘樹的前半部分。后半部分要在用戶的C里根據(jù)需要定義。
既得到如下結果:注意這是CL級別芯片的設置,如果芯片不同結果是不同的
HSE 外部高速時鐘 25MHZ 使能----------------------結果
PREDIV2 預分頻器2 1/5 -----------過程
PLL2MUL 鎖相環(huán)2倍頻器 8 -----------過程
PLL2CLK 鎖相環(huán)2時鐘 40MHZ 使能-----------------------結果
PREDIV1 預分頻器1 1/5 -----------過程
PLLMUL 鎖相環(huán)倍頻器 8 -----------過程
PLLCLK 鎖相環(huán)時鐘 72MHZ 使能-----------------------結果
SYSCLK 系統(tǒng)時鐘 72MHZ ---------------------------結果
HCLK 高級外設時鐘 72MHZ 9個外設都未使能------------結果
PCLK1 外設時鐘1 36MHZ 20個外設都未使能-----------結果
PCLK2 外設時鐘2 72MHZ 11個外設都未使能-----------結果
打個比方,供電局已經(jīng)把電通過變壓器配好電壓送到你們家
但家里的開關還沒有開,你要用的時候自己開,要用哪個開那個,這樣比較節(jié)能。