在一些需要特殊运算的应用电路中,只读存储器ROM是关键元件,设计人员通常利用ROM创建各种查找表,从而简化电路设计,提高电路的处理速度和稳定性。FPGA是基于SRAM的可编程器件。掉电后FPGA上的配置信息将全部丢失,所以由FPGA构造的数字系统在每次上电后要依赖于外部存储器来主动配置或在线被动配置。真正意义上的ROM应具有掉电后信息不丢失的特性,因此利用FPGA实现的ROM只能认为器件处于用户状态时具备ROM功能。使用时不必要刻意划分,而ROM单元的初始化则是设计人员必须面对的问题。本文讨论FPGA的ROM初始化问题,详细介绍mit文件的创建与使用。

2 基于FPGA的ROM的实现

基于MAX+PLUSⅡ软件平台,FPGA可编程器件实现ROM功能比较简单。只需运行MAX+PLUSⅡ,选择图形输入,在新建页的空白处双击并在弹出的对话框中选择d:\maxplus2\max2lib\mega_lpm,调用软件提供的参数可调库(mega_lpm),找出参数化ROM宏模块(lpm_rom),如图1所示。表1列出lpm_ROM宏模块的端口及参数设置。

根据需要选择必要的Address[]、q[]两个端口创建加法运算的查找表。引入lpm_ROM宏模块后,一定要把LPM_ADDRESS_CONTROL设置为″UNREGISTERED″,否则编译报错。本系统设计选用了Altera公司的FLEX10K系列的FPGA(EPF10K10LC84-4),其模块结构如图2所示。

引入lpm_ROM宏模块后,开始ROM的初始化,这是运用lpm_ROM宏模块做为系统开发的关键。ROM初始化就是要在对应的地址赋初始值以实现查找表的功能。在系统编译之前一定要先设置LPM_FILE参数。实际上就是要加入一个mif文件或hex文件。以下详细讨论在MAX+PLUSⅡ环境下mif文件的创建和使用。

3 lpm_ROM初始化及mif文件

3.1 mif文件的格式及创建

3.1.1 mif文件格式

mif文件是在编译和仿真过程中作为存储器(ROM或RAM)初始化输入的文件,即memory initialization file。mif文件格式为:

3.1.2 mif文件创建

mif文件的创建很简单,主要有两种方法,一种是在MAX+PLUSⅡ环境下,新建文件,选文本输入,保存为mif文件。另一种方法是建立一个txt文件,然后将扩展名改成mif即可。

3.2 mif文件的使用

依上述方法创建的mif文件只是一个空文件,在lpm_ROM宏模块的LPM_FILE中引入这样的文件,仅仅能帮助lpm_ROM宏模块通过编译并把所有的存储单元初始化为零。且在编译出现:Warning:Can't find data in initial memory content[MIF/HEX]file。

mif文件的格式是固定的,对于前4行(DEPTH,WIDTH,ADDRESS_RADIX,DATA_RADIX),前2个参数应与lpm_ROM宏模块LPM_WIDTHAD和LPM_WIDTH相关联,后2个参数为了方便一般设置为DEC(十进制)。关键是文件内容的begin与end之间的部分。mif文件的使用就是修改begin与end之间的内容。主要有两种修改方法。

3.2.1 mif文件的修改方法1

mif文件的使用,即修改begin与end之间的内容,最常用的就是高级语言法。本文借助实例给以说明,并给出相应的m(Matlab)语言程序。

设计要求:8位地址输入,8位数据输出,输出数等于地址高4位对应的数加低4位对应的数,即实现1个4位二进制加法的查找表。这里只用到lpm_ROM宏模块的Address[]、q []两个端口。lpm_ROM宏模块及mif文件格式如图3所示。

采用MATLAB语言产生含有begin与end之间内容的txt文件,M文件的内容为:

保存并运行,然后打开aaa.txt文件(默认路径C:\MATLAB701\aaa.txt),拷贝到mif文件的begin与end之间,即完成了对该文件的修改。使用高级语言修改mif文件速度快,准确度高且能实现复杂运算。适用于数据较多的场合。

mif文件的修改方法2是在MAX+PLUSⅡ环境下,直接修改lpm_ROM存储器的各存储单元的内容。步骤如下:先引入lpm_ROM宏模块,新建aa.mif文件并加载到LPM_FILE中,编译完成后,波形编辑,然后仿真。此时MAX+PLUSⅡ会增加一个initialize菜单,点击initialize->initialize memory…,即可在弹出的对话框中编辑存储器各单元内容,如图4所示。

各存储单元输入后,点击Export File…,在弹出的对话框中确定要输出的mif文件名,即完成了对mif文件的修改。这种方法适合数据量较小的场合,比较简单直观。

以四位二进制加法查找表为例,分别采用以上两种方法对mif文件进行修改,仿真如下图5所示。

仿真显示,两种方式下均正确实现了四位二进制加法查找表。

4 结束语

本文详细讨论了基于FPGA的mif文件创建与使用,对于mif文件创建与使用均给出了两种可行性的方法。mif文件具有固定格式,而对mif文件使用主要就是对mif。文件begin与end之间的内容进行修改。本文以四位二进制加法查找表的实现为例,给出了m(Matlab)语言源程序。

fpga初始化错误_FPGA的ROM初始化问题讨论相关推荐

  1. fpga初始化错误_FPGA低温启动失败

    本文来源:https://blog.csdn.net/shanekong/article/details/29923925 现象描述 在给 medium 板光端机做低温试验时,分别给发送版.接收板断电 ...

  2. (11)Xilinx BRAM或者ROM初始化文件.COE制作(FPGA不积跬步101)

    名言:成功的捷径就是努力. 1 什么是COE文件? COE文件是一种ASCII文本文件,文件头部定义数据基数(Radix),可以时2.10或16.数据以向量的形式给出,向量以分号结尾,向量之间用逗号隔 ...

  3. BOOT ROM 初始化内容、启动设备、镜像烧写

       目录 1 启动方式 1.1 串行下载 1.2 内部 BOOT 模式 1.3 BOOT ROM 初始化内容 2 启动设备 3 镜像烧写 3.1 IVT 和 Boot Data 数据 3.2 DCD ...

  4. matlab读mif文件,利用matlab进行ROM初始化mif文件方法

    工具使用版本:Quartus II 13.0+Matlab2012d 撰写人:Strive_JP 关于FPGA中ROM初始化,最近学会了利用matlab强大的数据处理能力来初始化ROM当中的数据. 先 ...

  5. Adobe flash cs5 的Java运行时环境初始化错误 完美解决方法

    Adobe flash cs5 的Java运行时环境初始化错误 完美解决方法 下载网络上的Adobe flash cs5 精简版(绿色版),Java运行时环境初始化时出现错误,你可能需要重装Flash ...

  6. 避免Unity变量初始化错误的8条建议

    洪流学堂,让你快人几步. 本篇内容来自洪流读书会解读书籍<代码大全2>. 声名好变量以后就是变量的初始化了.不合理地初始化数据是产生编程错误的常见根源之一.掌握一些能够避免初始化问题的行之 ...

  7. 关于请设置注册表项Framewoke.....初始化错误的解决办法

    关于请设置注册表项Framework-初始化错误的解决办法) 本人电脑运行环境windows7 百度过很多网上所谓的解决办法,如下 1.重新下载/更高版本的Framework--本人正在使用最新的Fr ...

  8. .Net framework初始化错误

    在win7上运行一些程序的时候,有时候会弹出一个对话框:若要运行此应用程序,您必须首先安装 .NET Framework 的以下版本之一:  v4.0.30319有关如何获取.NET Framewor ...

  9. maple激活后不联网就会初始化错误解决方案——添加虚拟网卡

    引言 最近安装了maple2018版,激活后发现一个问题,程序启动显示"maple初始化错误".软件安装过程已经参照其他教程进行了激活.经过一番摸索发现,是因为maple启动时会检 ...

最新文章

  1. 一款高颜值的 MySQL 管理工具
  2. 基于TI TMS320C6678 + Xilinx Kintex-7 的高性能信号处理方案
  3. springmvc二十二:annotation-driven标签
  4. 也来谈谈RNN的梯度消失/爆炸问题
  5. 如何解决ajax跨域问题(转)
  6. 抖音联合巨量引擎、飞书推出五项举措 助中小企业共度疫情难关
  7. 李彦宏纳猛将,技术才是百度的未来
  8. hdu 2255 奔小康赚大钱 KM算法
  9. JSP页面添加播放视频功能
  10. 使用opencv和python进行智能图像处理pdf_OpenCV图像处理编程实例 PDF 高清版
  11. win10哪个版本打游戏好?win10游戏性能分析
  12. 技能高考的计算机教室,2020湖北技能高考成绩查询时间
  13. 时标网络图怎么画?详解两大画法
  14. Vue表单设计器的终极解决方案
  15. 获奖团队访谈录|“AI+无线通信赛道”二等奖团队
  16. RT-1052学习笔记 - GPIO架构分析
  17. git的项目创建和常用命令
  18. C++ qsort用法
  19. 如何在sql内写循环语句
  20. 微信小程序、app集成微信支付

热门文章

  1. Maven学习总结(42)——Maven多模块构建中常用的参数
  2. Nginx学习总结(1)——Nginx入门简介
  3. Tomcat学习总结(7)——Tomcat与Jetty比较
  4. Spring MVC学习总结(5)——SpringMVC项目关于安全的一些配置与实现方式
  5. 霍兰德职业兴趣测试题
  6. mysql 39 t.id 39_ERROR 2003 (HY000): Can#39;t connect to MySQL server on #39;10.16.115.101#39; (1...
  7. 页面中php传值后循环列表js获取点击的id
  8. tomcat日志输出控制
  9. 《从问题到程序:用Python学编程和计算》——2.6 简单脚本程序
  10. Lua实现二进制串与Hex显示串的相互转换