一、coe格式
Xilin ROM的初始化文件,ISE初始化ROM的時候要用擴展名為coe的文件。其格式如下:
MEMORY_INITIALIZATION_TADIX=2; //2表示數據是二進制格式,也可以是8,10,16
MEMORT_INITIALITION_VECTOR=
01110100,
00100000,
11110101,
……
二、bin格式
bin格式是純數據本身,不包含任何地址信息,燒寫或下載時通常需要制定地址。
三、intel hex格式
記錄格式
Intel HEX由任意數量的十六進制記錄組成。每個記錄包含5個域,它們按以下格式排列:
:llaaaatt[dd…]cc
每一組字母對應一個不同的域,每一個字母對應一個十六進制編碼的數字。每一個域由至少兩個十六進制編碼數字組成,它們構成一個字節,就像以下描述的那樣:
: 每個Intel HEX記錄都由冒號開頭。
ll 是數據長度域,它代表記錄當中數據字節(dd…)的數量。
aaaa 是地址域,它代表記錄當中數據的起始地址。
tt 是代表HEX記錄類型的域,它可能是以下數據當中的一個:
00 – 數據記錄
01 – 文件結束記錄
02 – 擴展段地址記錄
04 – 擴展線性地址記錄
dd 是數據域,它代表一個字節的數據。一個記錄可以有許多數據字節。記錄當中數據字節的數量必須和數據長度域(ll)中指定的數字相符。
cc 是校驗和域,它表示這個記錄的校驗和。校驗和的計算是通過將記錄當中所有十六進制編碼數字對的值相加,以256為模進行以下補足。
00-數據記錄
Intel HEX文件由任意數量以回車換行符結束的數據記錄組成。數據記錄外觀如下:
:10246200464C5549442050524F46494C4500464C33
其中:
10 是這個記錄當中數據字節的數量。
2462 是數據將被下載到存儲器當中的地址。
00 是記錄類型(數據記錄)
464C…464C是數據。
33 是這個記錄的校驗和。
04-擴展線性地址記錄(HEX386)
擴展線性地址記錄也叫作32位地址記錄或HEX386記錄。這些記錄包含數據地址的高16位。擴展線性地址記錄總是有兩個數據字節,外觀如下:
:02000004FFFFFC
其中:
02 是這個記錄當中數據字節的數量。
0000 是地址域,對于擴展線性地址記錄,這個域總是0000.
04 是記錄類型 04(擴展線性地址記錄)
FFFF 是地址的高16位。
FC 是這個記錄的校驗和,計算方法如下:
01h + NOT(02h + 00h + 00h + 04h + FFh + FFh)。
當一個擴展線性地址記錄被讀取,存儲于數據域的擴展線性地址被保存,它被應用于從Intel HEX文件讀取來的隨后的記錄。線性地址保持有效,直到它被另外一個擴展地址記錄所改變。
通過把記錄當中的地址域與被移位的來自擴展線性地址記錄的地址數據相加獲得數據記錄的絕對存儲器地址。
示例
以下的例子演示了這個過程。.
來自數據記錄地址域的地址 2462
擴展線性地址記錄的數據域 + FFFF
絕對存儲器地址 FFFF2462
02-擴展段地址記錄(HEX86)
擴展段地址記錄也叫HEX86記錄,它包括4-19位數據地址段。擴展段地址記錄總是有兩個數據字節,外觀如下:
:020000021200EA
其中:
02 是記錄當中數據字節的數量。
0000 是地址域。對于擴展段地址記錄,這個域總是0000.
02 是記錄類型 02(擴展段地址記錄)
1200 是地址段。
EA 是這個記錄的校驗和,計算方法如下:
01h + NOT(02h + 00h + 00h + 02h + 12h + 00h)。
當一個擴展段地址記錄被讀取,存儲于數據域的擴展段地址被保存,它被應用于從Intel HEX文件讀取來的隨后的記錄。段地址保持有效,直到它被另外一個擴展地址記錄所改變。
通過把記錄當中的地址域與被移位的來自擴展段地址記錄的地址數據相加獲得數據記錄的絕對存儲器地址。
以下的例子演示了這個過程。.
來自數據記錄地址域的地址 2462
擴展段地址記錄數據域 + 1200
絕對存儲器地址 00014462
01-文件結束(EOF)記錄
Intel HEX文件必須以文件結束(EOF)記錄結束。這個記錄的記錄類型域的值必須是01.EOF記錄外觀總是如下:
:00000001FF
其中:
00 是記錄當中數據字節的數量。
0000 是數據被下載到存儲器當中的地址。在文件結束記錄當中地址是沒有意義被忽略的.0000h是典型的地址。
01 是記錄類型 01(文件結束記錄)
FF 是這個記錄的校驗和,計算方法如下:
01h + NOT(00h + 00h + 00h + 01h)。
Intel HEX文件例子:
下面是一個完整的Intel HEX文件的例子:
:10001300AC12AD13AE10AF1112002F8E0E8F0F2244
:10000300E50B250DF509E50A350CF5081200132259
:03000000020023D8
:0C002300787FE4F6D8FD7581130200031D
:10002F00EFF88DF0A4FFEDC5F0CEA42EFEEC88F016
:04003F00A42EFE22CB
:00000001FF
Intel HEX文件是由一行行符合Intel HEX文件格式的文本所構成的ASCII文本文件。在Intel HEX文件中,每一行包含一個HEX記錄。這些記錄由對應機器語言碼和/或常量數據的十六進制編碼數字組成。Intel HEX文件通常用于傳輸將被存于ROM或者EPROM中的程序和數據。大多數EPROM編程器或模擬器使用Intel HEX文件。
四、mif文件
mif文件是altera ROM的初始化文件(hex亦可)。mif文件是在編譯和仿真過程中作為存儲器(ROM或RAM)初始化輸入的文件,即memory initialization file。mif文件格式為:
1
2
% multiple-line comment
multiple-line comment %
– single-line comment
DEPTH = 32; – The size of data in bits
WIDTH = 8; – The size of memory in words
ADDRESS_RADIX = HEX; – The radix for address values
DATA_RADIX = BIN; – The radix for data values
CONTENT – start of (address : data pairs)
BEGIN
00 : 00000000; – memory address : data
01 : 00000001;
02 : 00000010;
03 : 00000011;
04 : 00000100;
05 : 00000101;
06 : 00000110;
07 : 00000111;
08 : 00001000;
09 : 00001001;
0A : 00001010;
0B : 00001011;
0C : 00001100;
END;
mif文件的格式是固定的,對于前4行(DEPTH,WIDTH,ADDRESS_RADIX, DATA_RADIX),前2個參數應與lpm_ROM宏模塊LPM_WIDTHAD和LPM_WIDTH相關聯,后2個參數為了方便一般設置為DEC (十進制)。關鍵是文件內容的begin與end之間的部分。mif文件的使用就是修改begin與end之間的內容。
-
ROM
+關注
關注
4文章
577瀏覽量
86751 -
RAM
+關注
關注
8文章
1384瀏覽量
116138
發布評論請先 登錄
相關推薦
關于Quartus II中ROM初始化數據.mif格式文件,在Modelsim中仿真...
阻止RAM和初始化文件
適用于IPTV大并發應用的文件格式
CD-ROM映像文件格式轉換工具
FPGA的ROM初始化問題討論

在51平臺下初始化文件的引入導致全局變量無法初始化的問題如何解決

想要對RAM初始化該怎么操作
根據MATLAB中的偽隨機交織器產生的交織圖案初始化到ROM的實驗

STM32--hex文件格式

WAV文件格式詳解

評論