?? hex中文版.txt
字號:
本文由AthlonxpX86(桃源村) 翻譯<>中的內(nèi)容為譯者加入的內(nèi)容
問題:
什么是Intel HEX格式?
回答:
Intel HEX文件是記錄文本行的ASCII文本文件,下面是Intel HEX文件格式,在Intel HEX文件中,每一行是一個HEX記錄由十六進(jìn)制數(shù)組成的機(jī)器碼或者靜態(tài)數(shù)據(jù),Intel HEX文件經(jīng)常被用于將程序或數(shù)據(jù)傳輸存儲到ROM.EPROM,大多數(shù)編程器和模擬器使用Intel HEX文件.
記錄格式:
一個Intel HEX文件可以包含任意多的十六進(jìn)制記錄,每條記錄有五個域,下面是一個記錄的格式.
:llaaaatt[dd...]cc
每一組字母是獨立的一域,每一個字母是一個十六進(jìn)制數(shù)字,每一域至少由兩個十六進(jìn)制數(shù)字組成,下面是字節(jié)的描述.
: 冒號是每一條Intel HEX記錄的開始
ll 是這條記錄的長度域,他表示數(shù)據(jù)(dd)的字節(jié)數(shù)目.
aaaa 是地址域,他表示數(shù)據(jù)的起始地址<如果是數(shù)據(jù)記錄這表示將要燒錄的這條記錄中的數(shù)據(jù)在EPROM中的偏移地址,對于不支持?jǐn)U展段地址和擴(kuò)展線性地址的如89C51,這就是此條記錄的起始地址>
tt 這個域表示這條HEX記錄的類型,他有可能是下面這幾種類型
00 ----數(shù)據(jù)記錄<要分清楚這幾種記錄類型,后面會經(jīng)常出現(xiàn),不要搞混了>
01 ----文件結(jié)束記錄<HEX文件的最后一條記錄這個域是01>
02 ----擴(kuò)展段地址記錄
04 ----擴(kuò)展線性地址記錄
dd 是數(shù)據(jù)域,表示一個字節(jié)的數(shù)據(jù),一個記錄可能有多個數(shù)據(jù)字節(jié),字節(jié)數(shù)目可以查看ll域的說明
cc 是效驗和域,表示記錄的效驗和,計算方法是將本條記錄冒號開始的所有對字母<不包括本效驗字和冒號>所表示的十六進(jìn)制數(shù)字<一對字母表示一個十六進(jìn)制數(shù),這樣的一個十六進(jìn)制數(shù)為一個字節(jié)>都加起來然后模除256得到的余數(shù)最后求出余數(shù)的補碼即是本效驗字節(jié)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++;
>
一
數(shù)據(jù)記錄
Intel HEX文件由若干個數(shù)據(jù)記錄組成,一個數(shù)據(jù)記錄以一個回車和一個換行結(jié)束<回車為0x0D換行為0x0A>
比如下面的一條數(shù)據(jù)記錄
:10246200464C5549442050524F46494C4500464C33
10是此行記錄數(shù)據(jù)的字節(jié)數(shù)目
2462是數(shù)據(jù)在內(nèi)存<將要燒寫的EPROM地址>中的起始地址
00是記錄類型00(是一個數(shù)據(jù)記錄)
464C到464C是數(shù)據(jù)
33是此行記錄的效驗和
二
擴(kuò)展線性地址記錄(HEX386)
擴(kuò)展線性地址記錄也可以認(rèn)為是32為地址記錄和HEX386記錄,這個紀(jì)錄包含高16(16-31位)位數(shù)據(jù)地址,這種擴(kuò)展的線性記錄總是有兩個字節(jié)數(shù)據(jù),像下面這樣:
:02000004FFFFFC
02是記錄的數(shù)據(jù)字節(jié)數(shù)目
0000是地址域這在擴(kuò)展地址記錄中總是0000
04是記錄類型04(擴(kuò)展地址記錄)
FFFF是高16位地址
FC是記錄效驗和,計算方法如下:
01h + NOT(02h + 00h + 00h + 04h + FFh + FFh)
當(dāng)一個擴(kuò)展線性地址記錄被讀到后,擴(kuò)展線性地址記錄的數(shù)據(jù)區(qū)域?qū)⒈槐4娌?yīng)用到后面從Intel HEX文件中讀出的記錄,這個擴(kuò)展線性記錄一直有效,直到讀到下一個擴(kuò)展線性記錄.
絕對內(nèi)存地址 = 數(shù)據(jù)記錄中的地址 + 移位后的擴(kuò)展線性地址
| |
數(shù)據(jù)記錄中的地址域 移位后擴(kuò)展線性地址記錄中的地址域
下面舉例說明這個過程
從數(shù)據(jù)記錄的地址域得到地址 2462
從擴(kuò)展線性地址記錄的地址域得到地址 FFFF
--------
絕對內(nèi)存地址 FFFF2462
三
擴(kuò)展段地址記錄 (HEX86)
擴(kuò)展段地址記錄也可以認(rèn)為是包含地址中4-19位的數(shù)據(jù)地址段,這個擴(kuò)展段地址記錄總是有兩字節(jié)數(shù)據(jù),如下:
:020000021200EA
02是記錄中的數(shù)據(jù)字節(jié)數(shù)目
0000是地址域,在擴(kuò)展段地址記錄中,這個域總是0000
02是記錄類型02(擴(kuò)展段地址的標(biāo)示)
1200是該段的地址
EA是效驗和計算如下:
01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).
當(dāng)擴(kuò)展段地址記錄被讀后,擴(kuò)展段地址將被存儲并應(yīng)用到以后從Intel HEX文件讀出的記錄,這個段地址一直有效直到讀到下一個擴(kuò)展段地址記錄
絕對內(nèi)存地址 = 數(shù)據(jù)記錄中的地址 + 移位后的擴(kuò)展段地址
| |
數(shù)據(jù)記錄中的地址域 移位后擴(kuò)展段地址記錄中的地址域
下面舉例說明這個過程
從數(shù)據(jù)記錄的地址域得到地址 2462
從擴(kuò)展段地址記錄的地址域得到地址 1200
--------
絕對內(nèi)存地址 00014462
四
文件結(jié)束記錄(EOF)
一個Intel HEX文件必須有一個文件結(jié)束記錄,這個記錄的類型域必須是01,一個EOF記錄總是這樣:
:00000001FF
00是記錄中數(shù)據(jù)字節(jié)的數(shù)目
0000這個地址對于EOF記錄來說無任何意義
01記錄類型是01(文件結(jié)束記錄標(biāo)示)
FF是效驗和計算如下
01h + NOT(00h + 00h + 00h + 01h).
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -