【轉】單片機HEX文件徹底解讀

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

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

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

:0E00030075801175902275A03375B04480FE93
:03000000020011EA
:0C001100787FE4F6D8FD7581070200033B
:00000001FFhtm

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

通常單片機程序不會超過64K,因此一般數據類型只會出現00或者01,固然其它狀況筆者尚未太深刻研究。內存

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

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

 

 

 

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的補碼。

相關文章
相關標籤/搜索