【lattice软核】ROM的使用
=======================》》》》》
一、ROM核调用:==================》》》》》
=======================》》》》》


=======================》》》》》
二、ROM表的生成:==================》》》》》
=======================》》》》》
查看内存使用手册,如图可以找到,我的是MachXO2系列芯片


在手册中查看.mem文件需要的格式




了解了文件数据格式,那么就需要编写数据了,数据可以自己计算来填写,比如编一个1024*8的正弦波表,但是手工麻烦
下面介绍下工具,我暂时没找到更好的工具,如果大家有更好的工具希望能告知。当然也可以用execl,matlab等实现。

软件下载页面点此下载
使用方法
1、查看--全局参数里设置一下

2、点设定波形--正弦波。就有了波形数据了
3、点保存,保存为mif文件。 此时保存的文件和.mem需要的内容格式不同,需要手动修改,打开文件如图

每行后的分号也需要去掉哦
在最后一行还有个END,记得删除
4、另保存为.mem格式(记事本似乎不可以竖列选,我用的是notepad++,其他高级编辑器也都可以)
5、回到IP核调用那块重新调用,把这个文件添加进去,选择hex文件格式的,生成
=======================》》》》》
三、ROM软核添加进工程:==================》》》》》
=======================》》》》》
1、打开工程目录,找到刚才省成的rom.v文件,拖放到diamond的source文件

=======================》》》》》
四、rom核的使用:==================》》》》》
=======================》》》》》
我现在要写一个ROM直接接DAC输出正弦波的,则要考虑时序,查看手册


DAC的时序如下

具体分析自己看,可以看出需要在时钟下降沿改变地址,上升沿时保持稳定
则代码如下
/*--------------------------------------------------------------------------------------
-- Filename ﹕ dac.v
-- Author ﹕tony-ning
-- Description ﹕DAC硬件测试 ,10M方波,AD9760
-- Called by ﹕Top module
-- Revision History ﹕15-10-16
-- Revision 1.0
-- Company ﹕
-- Copyright(c) All right reserved
---------------------------------------------------------------------------------------*/ module dac
(
input CLK25, //输入25M时钟
output CLK_DA,//输出给DAC的100M时钟
output [:]date_out
); reg [:]count2; always @( negedge CLK)//地址累加,下降沿改变
begin
count2<=count2+;//改变累加数字可改变输出频率
end assign CLK_DA=CLK;//时钟输出 pll PLL100M//锁相环倍频
(
.CLKI(CLK25),
.CLKOP(CLK)
); rom_sin sin//调用rom核,
(
.Address(count2), //地址
.OutClock(CLK), //时钟
.OutClockEn('b1), //输出使能,高有效
.Reset('b0), //复位,高有效
.Q(date_out)
); endmodule
【lattice软核】ROM的使用的更多相关文章
- 【lattice软核】MICO8流程
The LatticeMico System software is composed of three bundled applications: Mico System Builder (MS ...
- Spartan6上软核系统自定义外设调用AXI Stream FFT经验
这几天希望能在Spartan系列新品xc6slx16csg324-2运行带有FFT的软核处理系统,基本系统早就搭建好了.需要做的就是建立一个封装有Xilinx提供的FFT IP的自定义外设.由于Xil ...
- 【小梅哥FPGA进阶教程】MC8051软核在FPGA上的使用
十.MC8051软核在FPGA上的使用 本教程内容力求以详细的步骤和讲解让读者以最快的方式学会 MC8051 IP core 的应用以及相关设计软件的使用,并激起读者对 SOPC 技术的兴趣.本实验重 ...
- wrHDL编译中软核代码初始化及编译耗时长的问题
问题的提出整个WR的ISE工程比较大,编译时间很长,导致开发效率低.通过分析发现,ISE在综合的时候大量的时间都花在了初始化DPRAM上.调研发现Xilinx提供了BMM文件和DATA2MEM工具,可 ...
- [置顶]
基于FPGA的VGA简易显存设计&NIOS ii软核接入
项目简介 本项目基于Altera公司的Cyclone IV型芯片,利用NIOS II软核,2-port RAM与时序控制模块,实现64*48分辨率的显存(再大的显存板载资源m9k不够用) 实现效果如下 ...
- ISE创建Microblaze软核(三)
第七步 进入SDK开发环境 编译完成后弹出如下对话框,选择SDK的工作目录.在MicroblazeTutor中创建一个Workspace文件夹,并选择该文件夹为SDK的工作目录. 进入SDK主界面. ...
- ISE创建Microblaze软核(二)
ISE创建Microblaze软核(二) (2012-07-13 15:09:08) 转载▼ 标签: 杂谈 分类: FPGA开发 第四步 进入Platform Studio操作界面 通过向导创建软核后 ...
- ISE创建Microblaze软核(一)
在使用FPGA时,有时会用到它做为主控芯片.对于习惯于单片机及C语言开发的人,使用FPGA做主控芯片,首先还是想到它的嵌入式软核功能.如果能够基于Microblze软核进行C语言程序的开发,相对于使用 ...
- FPGA的软核与硬核
硬核 zynq和pynq系列的fpga都是双ARM/Cortex-A9构成,这里的ARM处理器为硬核,Cortex-A9部分为FPGA部分.即整体分为两部分:PS/PL.PS部分为A9处理器部分,PL ...
随机推荐
- Xcode5中如何切换Storyboards为xib
在Xcode5中,当创建一个带View的iPhone项目时,默认必须使用Storyboards,不再支持切换xib的checkbox.本文讲解如何手动切换到使用xib来布局. 1,把Main.stor ...
- PHP interface(接口)的示例代码
<?php class DocumentStore { protected $data = []; public function addDocument(Documentable $docum ...
- GUI 下
11.6 Swing组件 JButton JLabel JTextField JTextArea JTable JTree publicclass JTableDemo extends JFrame ...
- C#委托,事件理解入门 (译稿)
原文地址:http://www.codeproject.com/Articles/4773/Events-and-Delegates-Simplified 引用翻译地址:http://www.cnbl ...
- Sprint第三阶段(第三天12.11)
- 编辑距离——Edit Distance
编辑距离 在计算机科学中,编辑距离是一种量化两个字符串差异程度的方法,也就是计算从一个字符串转换成另外一个字符串所需要的最少操作步骤.不同的编辑距离中定义了不同操作的集合.比较常用的莱温斯坦距离(Le ...
- 事件委托和JQ事件绑定总结
事件委托: 比喻:事件委托的事例在现实当中比比皆是.比如,有三个同事预计会在周一收到快递.为签收快递,有两种办法:一是三个人在公司门口等快递:二是委托给前台MM代为签收.现实当中,我们大都采用委托的方 ...
- ListView下拉加载二(分页)
这次在一的基础上做了数据通过HttpClient远程获取显示 并且分页,首先看下效果吧: 以上就是效果图了 下面看下具体代码实现吧 主要代码和上节差不多 主入口代码: package com.tp.s ...
- oracle中trim,ltrim,rtrim函数用法
该函数共有两种作用:第一种,即大家都比较熟悉的去除空格.例子:--TRIM去除指定字符的前后空格SQL> SELECT TRIM(' dd df ') FROM dual;TRIM('DDDF' ...
- 退役&&搬家
牡丹江与鞍山两站作为最后的结束站.一银一铜就此结束了~ 此博客用来怀念ACM就此保留并不添加任何其它与其无关内容. ------------------------------------------ ...