【轉】單片機HEX文件完全解讀


轉:http://www.eefocus.com/craftor/blog/10-07/193051_8ce59.html

Craftor原創,首發於與非網,轉載請保留此處。

HEX文件,是Intel公司提出的按地址排列的數據信息,數據寬度為字節,所有數據使用16進制數字表示。以下是一個HEX文件的內容:

:0E00030075801175902275A03375B04480FE93
:03000000020011EA
:0C001100787FE4F6D8FD7581070200033B
:00000001FF

解釋:冒號為每行數據的開始符號;藍色表示此行數據長度,十六進制,如0E就是14;紅色是數據存放的地址,如0003;粉紅色是表示數據類型,00表示數據記錄,01表示文件結束,02表示擴展段地址記錄,03表示開始段地址記錄,04表示擴展線性地址記錄,05表示開始線性地址記錄;后面緊跟着的是N位數據,長度由藍色的長度位決定;天藍色為校驗位。

一般單片機程序不會超過64K,所以通常數據類型只會出現00或者01,當然其它情況筆者還沒有太深入研究。

根據上面的分析,筆者寫了一個將HEX文件轉換成比特流文件的C程序,可以將常見的HEX文件寫到64K的比特文件里。該程序也是在上一篇筆者寫的51單片機軟核仿真的時候用到的,轉換后的比特文件,可以在ModelSim里用TCL腳本讀入到內存里,從而可以對該軟核進行具體程序的仿真運行。

本人喜歡開源,所以公布出C代碼。該程序運行會生成內容為65536行8位二進制數據的mem.txt文件,即64K的二進制數據。

 

 

 

Intel hex 文件常用來保存單片機或其他處理器的目標程序代碼。它保存物理程序存儲區中的目標代碼映象。一般的編程器都支持這種格式。
    Intel hex 文件全部由可打印的ASCII字符組成(可以用記事本打開),如下例所示:

        :2000000012014c75a800e4f508f509780a7a78e4f608dafcd283fcfded240af9a7050dbd81        

        :2000200000010ced2488ec34ff50edc283e4fcfded240af9e76d7013ed33e43c700d0dbd2a        

        :2000400000010ced2488ec34ff50e50509e50970020508e50924a8e50834fd50aee4f50874

    Intel hex 由一條或多條記錄組成,每條記錄都由一個冒號“:”打頭,其格式如下:

         :CCAAAARR...ZZ      

    其中:

CC   

    本條記錄中的數據字節數

AAAA   

    本條記錄中的數據在存儲區中的起始地址

RR   

    記錄類型:     

00 數據記錄 (data record)     
01 結束記錄 (end record)     
02 段記錄 (paragraph record)     
03 轉移地址記錄 (transfer address record)

...   

    數據域

ZZ   

    數據域校驗和

    Intel hex文件記錄中的數字都是16進制格式,兩個16進制數字代表一個字節。CC域是數據域中的實際字節數,地址、記錄類型和校驗和域沒有計算在內。校驗和是取記錄中從數據字節計數域(CC)到數據域(...)最后一個字節的所有字節總和的2的補碼。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM