【MCU】用Keil生成bin、匯編、C與匯編混合文件,再也不想debug了!
1、聊一聊
一首《Five Hundred Miles》送給跟bug菌一樣深漂的伙伴們! 今天跟大家詳細(xì)聊聊如何在Keil中生成bin文件、匯編文件、以及C與匯編混合文件,并且詳細(xì)介紹一下生成fromelf.exe工具的使用。
2、正文部分
1
話題引入
在使用Keil集成開(kāi)發(fā)環(huán)境中大伙使用頻率高的文件大概就是.hex吧,如果考慮內(nèi)存布局等會(huì)使用到.map文件,如果遇到了疑難bug還會(huì)在仿真過(guò)程中看一看匯編窗口欄。 然而bin文件作為嵌入式最為直接的固件,同樣也是我們非常需要獲得的文件,比如進(jìn)行遠(yuǎn)程升級(jí)等等,一方面可以直接通過(guò)其他hex轉(zhuǎn)bin工具轉(zhuǎn)化,另一方面通過(guò)集成開(kāi)發(fā)環(huán)境自帶的功能進(jìn)行轉(zhuǎn)化即可。 同樣有時(shí)候我們不想通過(guò)debug狀態(tài)下的匯編欄進(jìn)行匯編查看,而是想直接分析每個(gè)源文件編譯所生成的匯編文件來(lái)定位問(wèn)題和優(yōu)化性能,集成開(kāi)發(fā)環(huán)境能夠有生成匯編文件的功能就再方便不過(guò)了。2
生成bin文件
1
formelf.exe介紹
fromelf.exe即keil下的一個(gè)處理elf文件的工具,elf文件英文名為Executable and Linking Format ,該文件包括符號(hào)表,調(diào)試信息,匯編等等,所以通過(guò)使用fromelf.exe可以輸出較多信息文件,比如hex、bin、asm等。 對(duì)于此工具詳細(xì)的說(shuō)明文件可以參考: using_the_fromelf_utility.pdf
2
formelf.exe詳細(xì)說(shuō)明
1、首先在windows運(yùn)行欄中找到cmd命令輸入。
bug菌對(duì)上面的輸出簡(jiǎn)單的注釋了下。
1ARM image conversion utility 2fromelf [options] input_file 3 4Options: 5 --help display this help screen //【顯示幫助信息】 6 --vsn display version information//【顯示版本信息】 7 --output file the output file. (defaults to stdout for -text format)//【輸出文件。(-text格式默認(rèn)為stdout)】 8 --nodebug do not put debug areas in the output image//【不在輸出映像中放置調(diào)試域】 9 --nolinkview do not put sections in the output image//【不在輸出映像中放置段信息】 10 11Binary Output Formats: 12 --bin Plain Binary//【bin文件】 13 --m32 Motorola 32 bit Hex//【motol格式的hex文件】 14 --i32 Intel 32 bit Hex//【Intel格式的hex文件】 15 --vhx Byte Oriented Hex format//【面向字節(jié)的hex格式】 16 17 --base addr Optionally set base address for m32,i32 18 19Output Formats Requiring Debug Information 20 --fieldoffsets Assembly Language Description of Structures/Classes 21 --expandarrays Arrays inside and outside structures are expanded 22 23Other Output Formats: 24 --elf ELF 25 --text Text Information 26 27 Flags for Text Information 28 -v verbose 29 -a print data addresses (For images built with debug)//【打印數(shù)據(jù)地址信息】 30 -c disassemble code//【輸出匯編代碼】 31 -d print contents of data section//【打印數(shù)據(jù)域內(nèi)容】 32 -e print exception tables//【打印異常表】 33 -g print debug tables//【打印調(diào)試表】 34 -r print relocation information//【打印重定位信息】 35 -s print symbol table//【打印符號(hào)表】 36 -t print string table//【打印字符串表】 37 -y print dynamic segment contents//【打印動(dòng)態(tài)段內(nèi)容】 38 -z print code and data size information//【打印代碼與數(shù)據(jù)大小信息】
3
?????輸出bin和匯編
在keil中進(jìn)行如下配置 ,表示在工程編譯以后所執(zhí)行的命令行。 命令行如下,方便大伙copy:-
fromelf --text -c -o "$L@L.asm" "#L"
-
fromelf --bin -o "$L@L.bin" "#L"
確定配置好以后重新編譯,最終編譯器輸出如下信息。
從輸出信息來(lái)可以了解到bin文件和asm文件均由.axf文件通過(guò)fromelf工具轉(zhuǎn)化而來(lái),相信轉(zhuǎn)化命令的通配符大家也可以理解了,輸出結(jié)果如下:
這樣看來(lái).axf文件所包含的信息非常之多,其 全稱為:Arm executable File,其實(shí).axf文件與gcc中的elf文件是類似的,Keil默認(rèn)生成.axf文件 。
如果在Keil中沒(méi)有勾選hex文件的生成,那么就用.axf文件來(lái)進(jìn)行燒錄。 而如果勾選 了Hex文件生成,其實(shí)就是Keil通過(guò)調(diào)用fromelf將axf轉(zhuǎn)換為hex文件,所以編譯后可以在輸出文件中同時(shí)看到axf和hex文件。
3
C與匯編混合展示
我們打開(kāi)前面的.asm文件如下圖所示:
零零散散我們可以看到幾個(gè)C函數(shù),不過(guò)閱讀起來(lái)稍微有點(diǎn)吃力,大伙應(yīng)該還是比較喜歡閱讀debug時(shí)候匯編框中C語(yǔ)言與匯編語(yǔ)言一一對(duì)應(yīng)的形式,這樣也更好理解匯編語(yǔ)言。
1
生成.txt和.i文件
我們?cè)趉eil中勾選如下幾項(xiàng),然后進(jìn)行重新編譯。
其中在工程目錄的 *.txt即為匯編與C混合文件 ,而 *.i為經(jīng)過(guò)了預(yù)處理的文件 。
2
對(duì)比.c和.i文件
3
查看.txt文件
2、最后
好了,本文到此結(jié)束,enjoy,持續(xù)的輸出都需要一定的動(dòng)力,大家懂的!免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!