在STM32中,如果是在MDK下創(chuàng)建一個工程,一般都有提示是否加入Star up Code文件,這個就是啟動文件,這里有個誤區(qū),一般對于初學(xué)者來看,很容易誤以為STM32F10x.s這個啟動文件是STM32所有類型芯片的通用啟動文件,因此也自然不會去理會它的作用,事實(shí)上,這個啟動文件只是針對部分STM32系列,如果仔細(xì)看過它的啟動代碼就會發(fā)現(xiàn)里面很多中斷函數(shù)定義是沒有的,甚至有些和STM32F10x_it.c里的函數(shù)是有出路的,如果剛好用到了默認(rèn)的這個中斷服務(wù)子函數(shù)的話,程序一旦運(yùn)行到了中斷是找不到入口地址的,這樣就會莫名其妙地不知問題所在。STM32F10x.s是MDK提供的啟動代碼,從其里面的內(nèi)容看來,它只定義了3個串口,4個定時器。實(shí)際上STM32的系列產(chǎn)品有5個串口的型號,也只有有2個串口的型號,定時器也是,做多的有8個定時器。比如,如果你用的STM32F103ZET6,而啟動文件用的是STM32F10x.s的話,你可以正常使用串口1~3的中斷,而串口4和5的中斷,則無法正常使用。所以STM32F10x.s并不能適用所有的STM32型號,對于不同型號的STM32,正確做法是選擇不同的啟動文件。ST公司提供了3個啟動文件:startup_stm32f10x_ld.s
/startup_stm32f10x_md.s/startup_stm32f10x_hd.s 分別適用于小容量/中容量/大容量的STM32芯片,具體判斷方法如下:
本文引用地址:
http://www.sanyacts.com.cn/article/201611/320078.htm 小容量:FLASH≤32K
中容量:64K≤FLASH≤128K
大容量:256K≤FLASH
在啟動代碼中,補(bǔ)充幾點(diǎn):
啟動代碼中的兩條語句解釋:
一、PROC 為子程序開始,ENDP 為子程序結(jié)束
二、[weak] 的意思是該函數(shù)優(yōu)先級比較弱,如果其它地方定義了一個同名函數(shù),那么此處的這個函數(shù)就被取代了。語法格式為 EXPORT 標(biāo)號 {[WEAK]} 。EXPORT 可用GLOBAL代替。
對于_main函數(shù)的理解:
事實(shí)上,_main 和main是兩個完全不同的函數(shù)!_main代碼是編譯器自動創(chuàng)建的,因此無法找到_main代碼。MDK文檔中有一句說明:it is automatically craated by the linker when it sees a definition of main() .大體意思可以理解為:當(dāng)編譯器發(fā)現(xiàn)定義了main函數(shù),那么就會自動創(chuàng)建_main.
_main 和main的關(guān)系
_main 主要做兩件事:其一,C所需的資源;其二,調(diào)用main函數(shù)。這就不難理解為什么在啟動代碼調(diào)用的是_main ,最后卻能轉(zhuǎn)到main函數(shù)中去執(zhí)行的原因了。
AREA指令的理解
AREA指令是一個偽指令,用于段定義。ARM匯編程序由段組成,段是相對獨(dú)立的指令或數(shù)據(jù)單位,每個段由AREA偽指令定義,并定義段的屬性。
AREA參數(shù)說明:
* STACK——AREA指令的一個參數(shù),定義段名稱
* NOINIT——AREA指令的一個參數(shù),指定本數(shù)據(jù)段僅僅保留了內(nèi)在單元,而將句初始值寫入內(nèi)存單元,此時內(nèi)存單元值初始化為0
* READWRITE——指定本段為可讀可寫,數(shù)據(jù)段默認(rèn)為READWRITE.
READWRITE(讀寫)、READONLY(只讀)
*ALIGN——也是一個偽指令,指定對齊方式。ALIGN n 指令的對齊值有兩種選擇:n或者2^n
例子:開辟一個堆棧段,段名為STACK,定義為可讀可寫,將內(nèi)存單元初始化為0,對齊方式為8字節(jié)對齊。
AREA STACK,NOINIT,READWRITE,ALIGN=3
評論