單片機經常使用輸出格式--Intel 32 bit Hex

你們作嵌入式程序,總會碰到最終下數據的時候,若是有現成的FlashLoader固然好了,若是沒有、或者是須要轉化成APDU之類的方式來下數據的話,就要面對編譯器輸出的文件了。
bin文件當然是最好的,可是在基址不爲0,或者數據不連續的時候就很麻煩。因此咱們常見的格式有Intel 32 bit Hex和Motorola 32 bit/S2/S3 Hex兩種,爲避免你們走彎路,我簡單的寫一下我對這鼕鼕的一些瞭解:

Intel HEX文件是記錄文本行的ASCII文本文件,下面是Intel HEX文件格式,在Intel HEX文件中,每一行是一個HEX記錄由十六進制數組成的機器碼或者靜態數據,Intel HEX文件常常被用於將程序或數據傳輸存儲到ROM.EPROM,大多數編程器和模擬器使用Intel HEX文件. c++

記錄格式: 編程

一個Intel HEX文件能夠包含任意多的十六進制記錄,每條記錄有五個域,下面是一個記錄的格式. 數組

:llaaaatt[dd...]cc spa

每一組字母是獨立的一域,每個字母是一個十六進制數字,每一域至少由兩個十六進制數字組成,下面是字節的描述. 內存

:?冒號是每一條Intel HEX記錄的開始 編譯器

ll?是這條記錄的長度域,他表示數據(dd)的字節數目. it

aaaa?是地址域,他表示數據的起始地址<若是是數據記錄這表示將要燒錄的這條記錄中的數據在EPROM中的偏移地址,對於不支持擴展段地址和擴展線性地址的如89C51,這就是此條記錄的起始地址>
編譯

tt?這個域表示這條HEX記錄的類型,他有多是下面這幾種類型
00 ----數據記錄
01 ----文件結束記錄
02 ----擴展段地址記錄
04 ----擴展線性地址記錄
擴展

dd?是數據域,表示一個字節的數據,一個記錄可能有多個數據字節,字節數目能夠查看ll域的說明 程序

cc? 是效驗和域,表示記錄的效驗和,計算方法是將本條記錄冒號開始的全部對字母<不包括本效驗字和冒號>所表示的十六進制數字<一對字母表示一個十六進制數,這樣的一個十六進制數爲一個字節>都加起來而後模除256獲得的餘數最後求出餘數的補碼便是本效驗字節cc.
<例如:
:0300000002005E9D
cc=0x01+NOT((0x03+0x00+0x00+0x00+0x02+0x00+0x5E)%0x100)=0x01+0x9C=0x9D
C語言描述:
UCHAR cc;
cc=(UCHAR)~(0x03+0x00+0x00+0x00+0x02+0x00+0x5E);
cc++;

一.數據記錄

Intel HEX文件由若干個數據記錄組成,一個數據記錄以一個回車和一個換行結束<回車爲0x0d換行爲0x0a>

好比下面的一條數據記錄
:10246200464C5549442050524F46494C4500464C33
10是此行記錄數據的字節數目
2462是數據在內存<將要燒寫的eprom地址>中的偏移地址
00是記錄類型00(是一個數據記錄)
464C到464C是數據
33是此行記錄的效驗和


擴展線性地址記錄(HEX386)
擴展線性地址記錄也能夠認爲是32爲地址記錄和HEX386記錄,這個紀錄包含高16(16-31位)位數據地址,這種擴展的線性記錄老是有兩個字節數據,像下面這樣:

:02000004FFFFFC
02是記錄的數據字節數目
0000是地址域這在擴展地址記錄中老是0000
04是記錄類型04(擴展地址記錄)
FFFF是高16位地址
FC是記錄效驗和,計算方法以下:
01h + NOT(02h + 00h + 00h + 04h + FFh + FFh)

當一個擴展線性地址記錄被讀到後,擴展線性地址記錄的數據區域將被保存並應用到後面從Intel HEX文件中讀出的記錄,這個擴展線性記錄一直有效,直到讀到下一個擴展線性記錄.


絕對內存地址 = 數據記錄中的地址? +? 移位後的擴展線性地址

????????????????????? |???????????????????? |

??????? 數據記錄中的地址域?? 移位後擴展線性地址記錄中的地址域

下面舉例說明這個過程

從數據記錄的地址域獲得地址????? ?????????? 2462
從擴展線性地址記錄的地址域獲得地址??????????? FFFF
????????????????????????????????????????????? --------
絕對內存地址?????????????????????? ?????? FFFF2462


三.擴展段地址記錄 (HEX86)

擴展段地址記錄也能夠認爲是包含地址中4-19位的數據地址段,這個擴展段地址記錄老是有兩字節數據,以下:
:020000021200EA
02是記錄中的數據字節數目
0000是地址域,在擴展段地址記錄中,這個域老是0000
02是記錄類型02(擴展段地址的標示)
1200是該段的地址
EA是效驗和計算以下:
01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).

當擴展段地址記錄被讀後,擴展段地址將被存儲並應用到之後從Intel HEX文件讀出的記錄,這個段地址一直有效直到讀到下一個擴展段地址記錄

絕對內存地址 = 數據記錄中的地址? +? 移位後的擴展段地址

????????????????????? |???????????????????? |

??????? 數據記錄中的地址域?? 移位後擴展段地址記錄中的地址域

下面舉例說明這個過程

從數據記錄的地址域獲得地址????? ?????????? 2462
從擴展段地址記錄的地址域獲得地址???????????????? 1200
????????????????????????????????????????????? --------
絕對內存地址?????????????????????? ?????? 00014462

四.文件結束記錄(EOF) 一個Intel HEX文件必須有一個文件結束記錄,這個記錄的類型域必須是01,一個EOF記錄老是這樣: :00000001FF 00是記錄中數據字節的數目 0000這個地址對於EOF記錄來講無任何意義 01記錄類型是01(文件結束記錄標示) FF是效驗和計算以下 01h + NOT(00h + 00h + 00h + 01h)

相關文章
相關標籤/搜索