chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

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

掃碼添加小助手

加入工程師交流群

1、話題引入

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

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

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

2、生成bin文件

1、formelf.exe介紹

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

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

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

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

2、formelf.exe詳細說明

1、首先在windows運行欄中找到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格式默認為stdout)】 8 --nodebug do not put debug areas in the output image//【不在輸出映像中放置調試域】 --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)//【打印數據地址信息】 -c disassemble code//【輸出匯編代碼】 -d print contents of data section//【打印數據域內容】 -e print exception tables//【打印異常表】 -g print debug tables//【打印調試表】 -r print relocation information//【打印重定位信息】35 -s print symbol table//【打印符號表】 -t print string table//【打印字符串表】 -y print dynamic segment contents//【打印動態(tài)段內容】 -z print code and data size information//【打印代碼與數據大小信息】

輸出bin和匯編

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

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

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

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

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

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

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

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

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

3、C與匯編混合展示

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

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

1、生成.txt和.i文件

我們在keil中勾選如下幾項,然后進行重新編譯。

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

2、對比.c和.i文件

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

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

3、查看.txt文件

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

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

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

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

責任編輯:haq

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

    關注

    90

    文章

    3708

    瀏覽量

    96768
  • keil
    +關注

    關注

    69

    文章

    1224

    瀏覽量

    171835

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    KEIL如何輸出bin文件?

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

    簡單的內聯匯編介紹

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

    RISC-V的工具鏈GCC內聯匯編

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

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

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

    GCC內聯匯編

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

    通過內聯匯編調用乘法指令mulh\\mulhsu\\mulhu

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

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

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

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

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

    匯編語言教學中文資料

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

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

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

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

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

    使用RASC生成Keil工程

    手動新建一個名為“Workspace_Keil”的文件夾,并將該文件夾作為我們的工作空間,我們的所有Keil工程都會放在這個文件夾里面。值得
    的頭像 發(fā)表于 05-15 14:46 ?892次閱讀
    使用RASC<b class='flag-5'>生成</b><b class='flag-5'>Keil</b>工程

    EE-134:為SHARC系列編寫C兼容匯編代碼中斷處理程序

    電子發(fā)燒友網站提供《EE-134:為SHARC系列編寫C兼容匯編代碼中斷處理程序.pdf》資料免費下載
    發(fā)表于 01-07 13:58 ?0次下載
    EE-134:為SHARC系列編寫<b class='flag-5'>C</b>兼容<b class='flag-5'>匯編</b>代碼中斷處理程序

    EE-128:C語言中的DSP:從C調用匯編類成員函數

    電子發(fā)燒友網站提供《EE-128:C語言中的DSP:從C調用匯編類成員函數.pdf》資料免費下載
    發(fā)表于 01-07 13:48 ?0次下載
    EE-128:<b class='flag-5'>C</b>語言中的DSP:從<b class='flag-5'>C</b>調用<b class='flag-5'>匯編</b>類成員函數

    TMS320C6000匯編語言工具v7.4用戶指南

    電子發(fā)燒友網站提供《TMS320C6000匯編語言工具v7.4用戶指南.pdf》資料免費下載
    發(fā)表于 12-30 16:42 ?3次下載
    TMS320<b class='flag-5'>C</b>6000<b class='flag-5'>匯編</b>語言工具v7.4用戶指南