找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2668|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

Hex文件格式與合并

  [復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
#
ID:262045 發(fā)表于 2022-6-10 11:38 | 只看該作者 回帖獎勵 |正序瀏覽 |閱讀模式
什么是hex文件
hex文件格式是可以燒寫到單片機中,被單片機執(zhí)行的一種文件格式,生成Hex文件的方式有很多種,可以通過不同的編譯器將C程序或者匯編程序編譯生成hex。

Hex文件格式:

先來看一下hex文件,主要截取了三部分,開頭1行



中間數(shù)據(jù),這里只截取了一部分作為表示



結(jié)尾2行



數(shù)據(jù)少不了數(shù)據(jù)格式(協(xié)議),先來看一看hex文件的數(shù)據(jù)格式,以第一行數(shù)據(jù)(020000040002f8)為例,看一看hex文件的每一字段數(shù)據(jù)是什么意思:

020000040002f8可以分解為:

0x02 0x00 0x00 0x04 0x02 0x02 0xf8,前面4個字節(jié)和最后一個字節(jié)是有特殊含義的,中間為數(shù)據(jù),每個字段的具體含義如下:

第一字節(jié)0x02:數(shù)據(jù)長度,即該行有多少個數(shù)據(jù);

第二、三字節(jié)0x00、0x00:表示本行數(shù)據(jù)的起始地址位;

第四個字節(jié)有0x00 0x01 0x02 0x03 0x04 0x05,分別有以下含義:

'00’Data Rrecord:用來記錄數(shù)據(jù),HEX文件的大部分記錄都是數(shù)據(jù)記錄

'01’文件結(jié)束記錄:用來標(biāo)識文件結(jié)束,放在文件的最后,標(biāo)識HEX文件的結(jié)尾

'02’擴展段地址記錄:用來標(biāo)識擴展段地址的記錄

'03’開始段地址記錄:開始段地址記錄

'04’擴展線性地址記錄:用來標(biāo)識擴展線性地址的記錄

'05’開始線性地址記錄:開始線性地址記錄

最后一個字節(jié)0xf8為校驗和:校驗和= 0x100 - 累加和

單純看上面的介紹,好像也看不出和MCU的FLASH地址如何聯(lián)系起來,接下來看看是如何跟FLASH地址對應(yīng)的



第一字節(jié)表示該行的數(shù)據(jù)字節(jié)數(shù);如第1行只有 0x08 0x00 兩個字節(jié)的數(shù)據(jù),類型是 04 ,即該行記錄的是一個拓展地址(0x08 0x00 是地址信息,用法是將該地址(0x0800<<16) 后作為基地址。并且表示在下一個04類型行出現(xiàn)之前都要使用該地址。

例如第2行的地址信息是 0x0000,則表示該行數(shù)據(jù)從0x08000000( (0x0800<<16) | 0x0000 )開始記錄。

第3行則從 0x08000010 ( (0x0800<<16) | 0x0010 )開始記錄。

另外最后一個字節(jié)的校驗和 0xD2 = 0xff & ( 0x100- (0x10+4*(0x00)+0x38+0x05+…+0x00+0x08) ) = 0xff & (0x100-0x2E);

然后再看結(jié)尾部分: 類型是05,有4字節(jié)數(shù)據(jù),從上面的介紹可以知道,05是指“開始線性地址記錄”,什么意思呢?

其實就是函數(shù)入口地址,從編譯產(chǎn)生的.map文件中,可以看到Image Entry point后面跟的就是這個值

例如第2行的地址信息是 0x0000,則表示該行數(shù)據(jù)從0x08000000( (0x0800<<16) | 0x0000 )開始記錄。

第3行則從 0x08000010 ( (0x0800<<16) | 0x0010 )開始記錄。

另外最后一個字節(jié)的校驗和 0xD2 = 0xff & ( 0x100- (0x10+4*(0x00)+0x38+0x05+…+0x00+0x08) ) = 0xff & (0x100-0x2E);

然后再看結(jié)尾部分: 類型是05,有4字節(jié)數(shù)據(jù),從上面的介紹可以知道,05是指“開始線性地址記錄”,什么意思呢?

其實就是函數(shù)入口地址,從編譯產(chǎn)生的.map文件中,可以看到Image Entry point后面跟的就是這個值





最后的一行,01代表文件結(jié)束,以上就是關(guān)于hex文件的簡單介紹。

合并hex文件的幾種方法
1、傳統(tǒng)而不優(yōu)雅的直接合并法
打開我們的hex文件,就以BOOT和APP代碼為例,用記事本或者其他的軟件(notepad++等)打開



從上面的介紹我們可以知道,hex文件最后一行是代表文件的結(jié)束,那么我們只需要刪除boot文件的最后一行代碼,然后把APP的代碼直接拷貝過來



這樣我們就得到了最終的hex文件,直接燒錄進去MCU即可

2、jflash燒錄
jlink說我們必不可少的燒錄調(diào)試工具之一,一起來看看怎么使用jlink自帶的jflash工具合并

打開jflash,首先選擇我們的第一個文件,file->open data file即可



打開之后,可以看到地址是從8000000開始的,也即是我們的MCU flash的基地址



然后再點擊file->merge data file



選擇我們的第二個文件,選擇打開之后,第二個hex文件就拼接到了BOOT文件之后了,保存文件即可,建議另存為我們需要的文件名,否則的話,會默認(rèn)為我們打開的第一個文件名

3、開源小工具
這個方法和上面jflash的方法類似,網(wǎng)上有很多熱心網(wǎng)友開發(fā)的小工具,也可以自己做一個,小飛哥就找一個自己測試過得給大伙用吧

軟件源碼開源,非本人所編寫,github地址為:https://github.com/SmartElec/STM32-IAP-HEX-Merge,源碼為C#所編寫。

下載下來有源碼,感興趣的就看看,不感興趣的就直接用即可,在realese文件夾內(nèi)



直接選擇我們的hex文件,注意順序



還可以同時生成bin文件,點擊合并即可



文件夾內(nèi)已經(jīng)生成了目標(biāo)hex合并文件



接下來就可以把所有文件合并之后,只燒錄一個hex文件啦
————————————————
版權(quán)聲明:本文為CSDN博主「Mr_Wyf」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/qq_16519885/article/details/123744104

評分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏8 分享淘帖 頂4 踩
回復(fù)

使用道具 舉報

樓主
ID:476527 發(fā)表于 2022-6-13 08:45 | 只看該作者
感謝轉(zhuǎn)載,雖然已經(jīng)知道怎么合并兩個hex文件,但對其原理還是有所疑惑,這篇文章很好的解決了我的問題。
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表