在研究固定系数乘法器的查超标法,需要用到ROM存储器,因此探究了下初步使用。
器件:altera Cyclone III
1.建立工程与主文件
2.建立ROM的初始化文件
由于ROM不可写入,因此其数据的存储需要一个初始化文件,里面预写入ROM中的存储数据。
在File->New...里选择Hex文件或MIF文件都可以,用MIF文件更加容易借助其他工具如MATLAB等进行修改与生成,因此选择MIF文件。
双击生成文件,并对文件数据进行修改。随便改了改里面的存储数值,地址与数值一致了。保存文件为rom.mif。
打开.mif文件可见其组织方式。
3.建立ROM IP核
本页设置数据位宽与数据深度,ROM类型(一般auto即可),输入地址的时钟与输出数据的时钟。
该页选择是否在数据输出端加入一个reg来减小延时,如果加入的话,数据会晚一个周期抵达。
该页添加rom.mif初始文件,注意地址一定要写全,否则会出现如下报错:
Error (127001): Can't find Memory Initialization File or Hexadecimal (Intel-Format) File ......
之后生成.v文件即可
4.实例化并编译
添加rom.v文件并实例化编译,用signaltap抓取信号观察结果。
可以观察到输出数据与输入地址之间差了两个周期,这是因为输入地址时打了一拍,输出数据时打了一拍。
若取消掉数据输出后面的reg,则输出数据波形如下: