魚在水里哭
級別: *
精華主題: * 篇
發(fā)帖數(shù)量: * 個
工控威望: * 點
下載積分: * 分
在線時間: (小時)
注冊時間: *
最后登錄: *
查看魚在水里哭的 主題 / 回貼
樓主  發(fā)表于: 2008-07-22 11:47
讀取FX2N的ROM時,軟件提示要在ROM刻錄機端設置以上的通信參數(shù),請設置INTEL HEX格式。讀取ROM還要密碼嗎?ROM刻錄機怎么設置呀?
centro
級別: *
精華主題: * 篇
發(fā)帖數(shù)量: * 個
工控威望: * 點
下載積分: * 分
在線時間: (小時)
注冊時間: *
最后登錄: *
查看centro的 主題 / 回貼
1樓  發(fā)表于: 2008-07-22 14:29
Intel HEX文件是由一行行符合Intel HEX文件格式的文本所構成的ASCII文本文件。在Intel HEX文件中,每一行包含一個HEX記錄。這些記錄由對應機器語言碼和/或常量數(shù)據(jù)的十六進制編碼數(shù)字組成。Intel HEX文件通常用于傳輸將被存于ROM或者EPROM中的程序和數(shù)據(jù)。大多數(shù)EPROM編程器或模擬器使用Intel HEX文件。

記錄格式
Intel HEX由任意數(shù)量的十六進制記錄組成。每個記錄包含5個域,它們按以下格式排列:
:llaaaatt[dd...]cc
每一組字母對應一個不同的域,每一個字母對應一個十六進制編碼的數(shù)字。每一個域由至少兩個十六進制編碼數(shù)字組成,它們構成一個字節(jié),就像以下描述的那樣:
: 每個Intel HEX記錄都由冒號開頭.
ll 是數(shù)據(jù)長度域,它代表記錄當中數(shù)據(jù)字節(jié)(dd)的數(shù)量.
aaaa 是地址域,它代表記錄當中數(shù)據(jù)的起始地址.
tt 是代表HEX記錄類型的域,它可能是以下數(shù)據(jù)當中的一個:
00 – 數(shù)據(jù)記錄
01 – 文件結束記錄
02 – 擴展段地址記錄
04 – 擴展線性地址記錄
dd 是數(shù)據(jù)域,它代表一個字節(jié)的數(shù)據(jù).一個記錄可以有許多數(shù)據(jù)字節(jié).記錄當中數(shù)據(jù)字節(jié)的數(shù)量必須和數(shù)據(jù)長度域(ll)中指定的數(shù)字相符.
cc 是校驗和域,它表示這個記錄的校驗和.校驗和的計算是通過將記錄當中所有十六進制編碼數(shù)字對的值相加,以256為模進行以下補足.

數(shù)據(jù)記錄
Intel HEX文件由任意數(shù)量以回車換行符結束的數(shù)據(jù)記錄組成.數(shù)據(jù)記錄外觀如下:
:10246200464C5549442050524F46494C4500464C33
其中:
10 是這個記錄當中數(shù)據(jù)字節(jié)的數(shù)量.
2462 是數(shù)據(jù)將被下載到存儲器當中的地址.
00 是記錄類型(數(shù)據(jù)記錄)
464C…464C是數(shù)據(jù).
33 是這個記錄的校驗和.

擴展線性地址記錄(HEX386)
擴展線性地址記錄也叫作32位地址記錄或HEX386記錄.這些記錄包含數(shù)據(jù)地址的高16位.擴展線性地址記錄總是有兩個數(shù)據(jù)字節(jié),外觀如下:
:02000004FFFFFC
其中:
02 是這個記錄當中數(shù)據(jù)字節(jié)的數(shù)量.
0000 是地址域,對于擴展線性地址記錄,這個域總是0000.
04 是記錄類型 04(擴展線性地址記錄)
FFFF 是地址的高16位.
FC 是這個記錄的校驗和,計算方法如下:
01h + NOT(02h + 00h + 00h + 04h + FFh + FFh).
當一個擴展線性地址記錄被讀取,存儲于數(shù)據(jù)域的擴展線性地址被保存,它被應用于從Intel HEX文件讀取來的隨后的記錄.線性地址保持有效,直到它被另外一個擴展地址記錄所改變.
通過把記錄當中的地址域與被移位的來自擴展線性地址記錄的地址數(shù)據(jù)相加獲得數(shù)據(jù)記錄的絕對存儲器地址.
以下的例子演示了這個過程..
來自數(shù)據(jù)記錄地址域的地址                              2462
擴展線性地址記錄的數(shù)據(jù)域                      + FFFF
                                  ------------
絕對存儲器地址                               FFFF2462

擴展段地址記錄(HEX86)
擴展段地址記錄也叫HEX86記錄,它包括4-19位數(shù)據(jù)地址段.擴展段地址記錄總是有兩個數(shù)據(jù)字節(jié),外觀如下:
:020000021200EA
其中:
02 是記錄當中數(shù)據(jù)字節(jié)的數(shù)量.
0000 是地址域.對于擴展段地址記錄,這個域總是0000.
02 是記錄類型 02(擴展段地址記錄)
1200 是地址段.
EA 是這個記錄的校驗和,計算方法如下:
01h + NOT(02h + 00h + 00h + 02h + 12h + 00h).
當一個擴展段地址記錄被讀取,存儲于數(shù)據(jù)域的擴展段地址被保存,它被應用于從Intel HEX文件讀取來的隨后的記錄.段地址保持有效,直到它被另外一個擴展地址記錄所改變.
通過把記錄當中的地址域與被移位的來自擴展段地址記錄的地址數(shù)據(jù)相加獲得數(shù)據(jù)記錄的絕對存儲器地址.
以下的例子演示了這個過程..
來自數(shù)據(jù)記錄地址域的地址                             2462
擴展段地址記錄數(shù)據(jù)域                      +  1200
                                 ---------
絕對存儲器地址                    00014462

文件結束(EOF)記錄
Intel HEX文件必須以文件結束(EOF)記錄結束.這個記錄的記錄類型域的值必須是01.EOF記錄外觀總是如下:
:00000001FF
其中:
00 是記錄當中數(shù)據(jù)字節(jié)的數(shù)量.
0000 是數(shù)據(jù)被下載到存儲器當中的地址.在文件結束記錄當中地址是沒有意義被忽略的.0000h是典型的地址.
01 是記錄類型 01(文件結束記錄)
FF 是這個記錄的校驗和,計算方法如下:
01h + NOT(00h + 00h + 00h + 01h).

Intel HEX文件例子:
下面是一個完整的Intel HEX文件的例子:
:10001300AC12AD13AE10AF1112002F8E0E8F0F2244
:10000300E50B250DF509E50A350CF5081200132259
:03000000020023D8
:0C002300787FE4F6D8FD7581130200031D
:10002F00EFF88DF0A4FFEDC5F0CEA42EFEEC88F016
:04003F00A42EFE22CB
:00000001FF