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