91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何用Keil生成bin、匯編、C與匯編混合文件?

Q4MP_gh_c472c21 ? 來源:最后一個bug ? 作者:bug君 ? 2021-03-09 13:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1、話題引入

在使用Keil集成開發(fā)環(huán)境中大伙使用頻率高的文件大概就是.hex吧,如果考慮內(nèi)存布局等會使用到.map文件,如果遇到了疑難bug還會在仿真過程中看一看匯編窗口欄。

然而bin文件作為嵌入式最為直接的固件,同樣也是我們非常需要獲得的文件,比如進(jìn)行遠(yuǎn)程升級等等,一方面可以直接通過其他hex轉(zhuǎn)bin工具轉(zhuǎn)化,另一方面通過集成開發(fā)環(huán)境自帶的功能進(jìn)行轉(zhuǎn)化即可。

同樣有時候我們不想通過debug狀態(tài)下的匯編欄進(jìn)行匯編查看,而是想直接分析每個源文件編譯所生成的匯編文件來定位問題和優(yōu)化性能,集成開發(fā)環(huán)境能夠有生成匯編文件的功能就再方便不過了。

2、生成bin文件

1、formelf.exe介紹

fromelf.exe即keil下的一個處理elf文件的工具,elf文件英文名為Executable and Linking Format ,該文件包括符號表,調(diào)試信息,匯編等等,所以通過使用fromelf.exe可以輸出較多信息文件,比如hex、bin、asm等。

對于此工具詳細(xì)的說明文件可以參考:using_the_fromelf_utility.pdf

該文檔網(wǎng)上很容易搜索到,這里就不板書了。

如果你想省點(diǎn)事,可以直接使用cmd輸出formelf.exe的幫助信息,過程如下。

2、formelf.exe詳細(xì)說明

1、首先在windows運(yùn)行欄中找到cmd命令輸入。

2、輸入命令行.fromelf.exe --help

bug菌對上面的輸出簡單的注釋了下。

ARM image conversion utilityfromelf [options] input_file

Options: --help display this help screen //【顯示幫助信息】 --vsn display version information//【顯示版本信息】 --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)試域】 --nolinkview do not put sections in the output image//【不在輸出映像中放置段信息】

Binary Output Formats: --bin Plain Binary//【bin文件】 --m32 Motorola 32 bit Hex//【motol格式的hex文件】 --i32 Intel 32 bit Hex//【Intel格式的hex文件】 --vhx Byte Oriented Hex format//【面向字節(jié)的hex格式】

--base addr Optionally set base address for m32,i32

Output Formats Requiring Debug Information --fieldoffsets Assembly Language Description of Structures/Classes --expandarrays Arrays inside and outside structures are expanded

Other Output Formats: --elf ELF --text Text Information

Flags for Text Information -v verbose -a print data addresses (For images built with debug)//【打印數(shù)據(jù)地址信息】 -c disassemble code//【輸出匯編代碼】 -d print contents of data section//【打印數(shù)據(jù)域內(nèi)容】 -e print exception tables//【打印異常表】 -g print debug tables//【打印調(diào)試表】 -r print relocation information//【打印重定位信息】35 -s print symbol table//【打印符號表】 -t print string table//【打印字符串表】 -y print dynamic segment contents//【打印動態(tài)段內(nèi)容】 -z print code and data size information//【打印代碼與數(shù)據(jù)大小信息】

輸出bin和匯編

在keil中進(jìn)行如下配置 ,表示在工程編譯以后所執(zhí)行的命令行。

命令行如下,方便大伙copy:

fromelf --text -c -o “$L@L.asm” “#L”

fromelf --bin -o “$L@L.bin” “#L”

確定配置好以后重新編譯,最終編譯器輸出如下信息。

從輸出信息來可以了解到bin文件和asm文件均由.axf文件通過fromelf工具轉(zhuǎn)化而來,相信轉(zhuǎn)化命令的通配符大家也可以理解了,輸出結(jié)果如下:

這樣看來.axf文件所包含的信息非常之多,其全稱為:Arm executable File,其實(shí).axf文件與gcc中的elf文件是類似的,Keil默認(rèn)生成.axf文件。

如果在Keil中沒有勾選hex文件的生成,那么就用.axf文件來進(jìn)行燒錄。

而如果勾選了Hex文件生成,其實(shí)就是Keil通過調(diào)用fromelf將axf轉(zhuǎn)換為hex文件,所以編譯后可以在輸出文件中同時看到axf和hex文件。

3、C與匯編混合展示

我們打開前面的.asm文件如下圖所示:

零零散散我們可以看到幾個C函數(shù),不過閱讀起來稍微有點(diǎn)吃力,大伙應(yīng)該還是比較喜歡閱讀debug時候匯編框中C語言與匯編語言一一對應(yīng)的形式,這樣也更好理解匯編語言。

1、生成.txt和.i文件

我們在keil中勾選如下幾項(xiàng),然后進(jìn)行重新編譯。

其中在工程目錄的*.txt即為匯編與C混合文件,而*.i為經(jīng)過了預(yù)處理的文件。

2、對比.c和.i文件

對于預(yù)處理過程主要是去掉注釋和展開宏等,下面我們對比一下源文件與.i文件。

7126eb62-7ec2-11eb-8b86-12bb97331649.png

3、查看.txt文件

生成的.txt即為C代碼與匯編的混合文件。

71337f12-7ec2-11eb-8b86-12bb97331649.png

原文標(biāo)題:用Keil生成bin、匯編、C與匯編混合文件,再也不想debug了!

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 編程
    +關(guān)注

    關(guān)注

    90

    文章

    3716

    瀏覽量

    97179
  • keil
    +關(guān)注

    關(guān)注

    69

    文章

    1230

    瀏覽量

    172629

原文標(biāo)題:用Keil生成bin、匯編、C與匯編混合文件,再也不想debug了!

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    keil實(shí)現(xiàn)cc++混合編程

    參考touchgfx生成的代碼,發(fā)現(xiàn)了一個不需要添加--cpp11 參數(shù)的解決方法,具體操作如下。 一、創(chuàng)建一個空白的C文件和頭文件在頭文件
    發(fā)表于 01-26 08:58

    Keil中進(jìn)行C代碼與匯編代碼的混合編程

    通常保存了返回地址。由于通常將 C 代碼生成匯編代碼的時候,會由編譯器管理子程序調(diào)用時的符號,返回地址等信息的保存,而手動寫匯編代碼時則需要自己保存返回地址。 以下在
    發(fā)表于 01-23 06:36

    C語言中可以嵌套匯編語言嗎?

    請問C語言中可以嵌套匯編語言嗎?
    發(fā)表于 12-15 08:14

    KEIL如何輸出bin文件?

    可以通過Keil自帶的fromelf工具將編譯生成的.axf文件轉(zhuǎn)換為.bin文件。 1、打開工程設(shè)置 Project → Options
    發(fā)表于 11-20 06:51

    簡單的內(nèi)聯(lián)匯編介紹

    前言1、在程序中我們可以嵌入匯編直接對我們加入的硬件進(jìn)行相應(yīng)的操作 2、在RISC-V架構(gòu)中定義的CSR寄存器需要使用特殊的 CSR 指令進(jìn)行訪問,如果在 C/C++程序中需要使用 CSR 寄存器
    發(fā)表于 10-30 08:04

    RISC-V的工具鏈GCC內(nèi)聯(lián)匯編

    具體實(shí)現(xiàn)方法和步驟 在RISC-V架構(gòu)中定義的CSR寄存器需要使用特殊的CSR指令進(jìn)行訪問,如果C、C++程序中需要訪問CSR寄存器,只能使用內(nèi)嵌匯編指令的方法。在C
    發(fā)表于 10-30 06:59

    采用匯編指示符來使用自定義指令

    ,.dword為插入雙字即64位。以下為演示過程: * 在main.c中編寫如下代碼 * 使用riscv-nuclei-elf-gcc main.c命令編譯main.c。 生成默認(rèn)名
    發(fā)表于 10-28 06:02

    GCC內(nèi)聯(lián)匯編

    GCC內(nèi)聯(lián)匯編 在蜂鳥內(nèi)核的NICE協(xié)處理器擴(kuò)展demo的insn.h文件中存在下面一段指令,用于定義對協(xié)處理器調(diào)用指令,demo中協(xié)處理器支持三條指令:lbuf從內(nèi)存中l(wèi)oad數(shù)據(jù)至行數(shù)據(jù)緩存
    發(fā)表于 10-24 07:46

    通過內(nèi)聯(lián)匯編調(diào)用乘法指令mulh\\mulhsu\\mulhu

    高32位 mulhsurd, rs1,rs2 將rs1當(dāng)作有符號數(shù),rs2當(dāng)作無符號數(shù)相乘,取高32位 2.由于C語言中的乘法符號,在經(jīng)過軟件編譯后生成匯編指令位mul指令,因此,想要驗(yàn)證
    發(fā)表于 10-24 06:52

    NucleiStudio如何生成.verilog文件和.dasm文件,以及對.dasm文件中自定義指令反匯編結(jié)果分析

    文件,以及對.dasm文件中自定義指令反匯編結(jié)果分析。 一、如何生成.verilog和.dasm文件文件
    發(fā)表于 10-24 06:33

    rt-thread studio debug生成了elf & map,為什么不生成匯編呢?

    開發(fā)中crash后dump出了現(xiàn)場,需要通過反匯編文件確定crash的lr & pc,大部分使用rtthread studio的環(huán)境是windows,在windows下倒反匯編文件
    發(fā)表于 09-18 07:13

    匯編語言教學(xué)中文資料

    電子發(fā)燒友網(wǎng)站提供《匯編語言教學(xué)中文資料.rar》資料免費(fèi)下載
    發(fā)表于 06-30 15:15 ?7次下載

    Windows環(huán)境下32位匯編語言中文資料

    電子發(fā)燒友網(wǎng)站提供《Windows環(huán)境下32位匯編語言中文資料.rar》資料免費(fèi)下載
    發(fā)表于 06-30 15:14 ?0次下載

    rt-thread studio debug生成了elf & map,為什么不生成匯編?

    開發(fā)中crash后dump出了現(xiàn)場,需要通過反匯編文件確定crash的lr & pc,大部分使用rtthread studio的環(huán)境是windows,在windows下倒反匯編文件
    發(fā)表于 06-11 06:42

    飛凌嵌入式ElfBoard ELF 1板卡-uboot編譯原理介紹

    譯->編譯->匯編->鏈接->生成elf文件->轉(zhuǎn)換為二進(jìn)制可支持bin文件。預(yù)編譯Pre-compile階段
    發(fā)表于 05-22 11:17