1. 程式人生 > >Intel Hex檔案格式說明

Intel Hex檔案格式說明

Intel HEX檔案是記錄文字行的ASCII文字檔案,在Intel HEX檔案中,每一行是一個HEX記錄
由十六進位制陣列成的機器碼或者資料常量,Intel HEX檔案經常被用於將程式或資料傳輸
儲存到ROM.EPROM,大多數程式設計器和模擬器使用Intel HEX檔案.

記錄格式

一個Intel HEX檔案可以包含任意多的十六進位制記錄,每條記錄有五個域,下面是一個記錄的格式.

:llaaaatt[dd...]cc

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

:冒號     是每一條Intel HEX記錄的開始

ll 是這條記錄的長度域,他表示資料(dd)的位元組數目.

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)

擴充套件段地址記錄也被稱為 HEX86記錄,   包含 4-19位的資料地址段,
這個擴充套件段地址記錄總是有兩位元組資料,如下:

:020000021200EA
02 是     記錄中的資料位元組數目
0000           是地址域,在擴充套件段地址記錄中,這個域總是0000
02           是記錄型別02(擴充套件段地址的標示)
1200     是該段的地址
EA     是效驗和
計算如下:
01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).

當擴充套件段地址記錄被讀後,擴充套件段地址將被儲存並應用到以後從Intel HEX檔案讀出的記錄,這個段地址一直有效直到讀到下一個擴充套件段地址記錄

絕對記憶體地址 = 資料記錄中的地址 + 移位後的擴充套件段地址


資料記錄中的地址域       移位後擴充套件段地址記錄中的地址域

下面舉例說明這個過程

從資料記錄的地址域得到地址                   2 4 6 2
從擴充套件段地址記錄的地址域得到地址           1 2 0 0
絕對記憶體地址                         0 0 0 1 4 4 6 2

檔案結束記錄(EOF)
一個Intel HEX檔案必須有一個檔案結束記錄,這個記錄的型別域必須是01,
一個EOF記錄總是這樣:
:00000001FF
00是記錄中資料位元組的數目
0000這個地址對於EOF記錄來說無任何意義
01記錄型別是01(檔案結束記錄標示)
FF是效驗和計算如下
01h + NOT(00h + 00h + 00h + 01h).
========================
總結


形如
:BBAAAATTHHHH...HHHHCC

BB: Byte
AAAA:資料記錄的開始地址,高位在前,地位在後
      因為這個格式只支援8bits,地址被倍乘
      所以,為了得到實際的PIC的地址,需要將 地址除以2
TT: Type
        00 資料記錄
        01 記錄結束
        04 擴充套件地址記錄(表示32位地址的字首,當然這種只能在 INHX32)
HHHH:一個字(Word)的資料記錄,高Byte在前,低Byte在後
      TT之後,總共有 BB/2 個字 的資料
CC: 一個Byte的CheckSum


因為PIC16F873A只有4K的程式空間

所以,不會有 TT=04的 Linear Address Record