altera小实验——ROM读取

简介: altera小实验——ROM读取

在研究固定系数乘法器的查超标法,需要用到ROM存储器,因此探究了下初步使用。

器件:altera Cyclone III

1.建立工程与主文件

2.建立ROM的初始化文件

由于ROM不可写入,因此其数据的存储需要一个初始化文件,里面预写入ROM中的存储数据。

在File->New...里选择Hex文件或MIF文件都可以,用MIF文件更加容易借助其他工具如MATLAB等进行修改与生成,因此选择MIF文件。

277ab32bbfa2a30229afd9b9780d1539_SouthEast.png

双击生成文件,并对文件数据进行修改。随便改了改里面的存储数值,地址与数值一致了。保存文件为rom.mif。

83161e87810bf9cd9a5fcd298d6a3410_SouthEast.png

打开.mif文件可见其组织方式。

fcb98ed29632aa170317a19a6ad8f5a5_SouthEast.png

3.建立ROM IP核

2bbb1bb6b49bd06f279961c0cf1f2287_SouthEast.png

本页设置数据位宽与数据深度,ROM类型(一般auto即可),输入地址的时钟与输出数据的时钟。

64412e6c17b5eb1ca9f1f6fc967ffae4_SouthEast.png

该页选择是否在数据输出端加入一个reg来减小延时,如果加入的话,数据会晚一个周期抵达。

ed8a791884868d9f5fba1df1e0f1d6fa_SouthEast.png

该页添加rom.mif初始文件,注意地址一定要写全,否则会出现如下报错:

Error (127001): Can't find Memory Initialization File or Hexadecimal (Intel-Format) File ......

之后生成.v文件即可

4.实例化并编译

添加rom.v文件并实例化编译,用signaltap抓取信号观察结果。

可以观察到输出数据与输入地址之间差了两个周期,这是因为输入地址时打了一拍,输出数据时打了一拍。

7798b8ac90ce8ea3134955a6c7722939_SouthEast.png

7326f77045995340679c3fb930dfda50_SouthEast.png

相关文章
|
存储 芯片 内存技术
Jlink使用技巧之读写SPI Flash存储芯片
Jlink使用技巧之读写SPI Flash存储芯片
1088 0
Jlink使用技巧之读写SPI Flash存储芯片
|
7月前
|
异构计算
FPGA片内ROM测试实验(二)
FPGA片内ROM测试实验
92 1
|
7月前
|
存储 数据格式 异构计算
FPGA片内ROM测试实验(一)
FPGA片内ROM测试实验
120 1
|
7月前
|
Shell
全志平台A40I 读写寄存器操作
全志平台A40I 读写寄存器操作
143 0
|
7月前
|
存储 API 开发工具
【ZYNQ】SD 卡读写及文件扫描实验
【ZYNQ】SD 卡读写及文件扫描实验
313 0
|
编解码 Linux
基于瑞芯微RV1109 Linux串口驱动调试心得(给正点原子DS100示波器点赞!)
基于瑞芯微RV1109 Linux串口驱动调试心得(给正点原子DS100示波器点赞!)
313 0
|
存储 芯片 内存技术
一块宝藏存储芯片【SD NAND】
一块宝藏存储芯片【SD NAND】
|
异构计算
nios ii小实验——SDRAM读写
nios ii小实验——SDRAM读写
257 0
nios ii小实验——SDRAM读写
嵌入式开发学习之--IIC读写EEPROM(上)
嵌入式开发学习之--IIC读写EEPROM(上)
嵌入式开发学习之--IIC读写EEPROM(上)
|
异构计算 内存技术
altera小实验——SRAM读取
altera小实验——SRAM读取
244 0