实验调试中出现的问题.doc

实验调试中出现的问题.doc

ID:59189544

大小:492.50 KB

页数:9页

时间:2020-10-30

实验调试中出现的问题.doc_第1页
实验调试中出现的问题.doc_第2页
实验调试中出现的问题.doc_第3页
实验调试中出现的问题.doc_第4页
实验调试中出现的问题.doc_第5页
资源描述:

《实验调试中出现的问题.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、一.Modelsim实验调试的问题1.编译过程中的问题1)新建工程后:如果这里选择是creatnewfile,一定记得这里把这里的Addfileastype改为verilog因为这里默认是VHDL.2)如果是addexistingfile:要把所有的工程文件,包括仿真文件放在projectlocation里面。或者在下面的选项卡中:选择copytoprojectdirectory!!注意了:由于我们用的软件都是自己破解的,所有,有时候即便选择了copytoprojectdirectory有时候编译还是会出错,所有

2、我们还是自己把工程文件,v拷贝到我们的工程目录中吧。。。。2.仿真中出现的问题:当编译成功之后我们就可以进行仿真了1)在仿真的时候有些版本的modelsim仿真出来的波形是直线原因是我们要注意把Optimization中的enableoptimization的选项取消了:2)当我们编译成功之后在仿真的过程中,还会经常碰到这样的错误:“#Errorloadingdesign”解答:loadingdesign的问题就是你对每个模块编译后的内容,也就是你在work库里出现的东西提示你加载设计错误,就是说明你加载的东西在

3、work库里没有,这的问题的原因有两个:(1)testbench没有写好(2)在modelsim编译的时候相关的文件没有添加到modelsim中。所以我们的对应的解决办法也有两个:A.虽然我们编译通过了,但是可能有些字符拼写错误。B.我们可以关掉软件,再重新打开重新编译,重新仿真。3)仿真时遇到如图所示的情况:不能看到全局时,可以通过工具栏里这两个符号进行调节,结果如图:上面问题虽然解决了,但是result结果却让人头疼,根本看不清是多少,此时,可以通过如下步骤把他修改成十进制数字,效果如下图所示:是不是可以看得

4、很清楚了。还可以修改字体的大小和颜色,通过如下步骤:全选所有信号,右键选择“properties”,出现对话框(右边的图),可以在“View”栏里选择颜色,在“Format”栏选择字体大小,默认的是17,我们改成37之后,效果如图:可以看得更加清楚。二.synplify实验调试中出现的问题1.第一个大问题就是大部分同学,不明确synplify到底是干什么的,在新建工程之后,当添加文件时竟然都把testbench也加入了工程中,导致run不通过!解答:Synplify、SynplifyPro和SynplifyPre

5、mier是Synplicity(Synopsys公司于2008年收购了Synplicity公司)公司提供的专门针对FPGA和CPLD实现的逻辑综合工具,Synplicity的工具涵盖了可编程逻辑器件(FPGAs、PLDs和CPLDs)的综合,验证,调试,物理综合及原型验证等领域。2.synplify不能综合状态机的“default”状态:编码风格中要求对case语句的使用要做到取值完全覆盖,用case来判断状态机的状态,然而用synplify综合时出warning:OTHERSclauseisnotsynthes

6、ized,这里什么没有综合的原因是什么?FSM分两大类:米里型和摩尔型,组成要素有输入(包括复位),状态(包括当前状态的操作),状态转移条件,状态的输出条件,图1为状态机结构图。设计FSM的方法和技巧多种多样,但是总结起来有两大类:第一种,将状态转移和状态的操作和判断等写到一个模块中。另一种是将状态转移单独写成一个模块,将状态的操作和判断等写到另一个模块中(在Verilog代码中,相当于使用两个“always”block)。其中较好的方式是后者。其原因如下:首先FSM和其他设计一样,最好使用同步时序方式设计,好处

7、不再赘述。而状态机实现后,状态转移是用寄存器实现的,是同步时序部分。状态的转移条件的判断是通过组合逻辑判断实现的,之所以第二种比第一种编码方式合理,就在于第二种编码将同步时序和组合逻辑分别放到不同的程序块中实现。这样做的好处不仅仅是便于阅读、理解、维护,更重要的是利于综合器优化代码,利于用户添加合适的时序约束条件,利于布局布线器实现设计。显式的FSM描述方法可以描述任意的FSM(参考Verilog第四版P181有限状态机的说明)。两个always模块。其中一个是时序模块,一个为组合逻辑。时序模块设计与书上完全一致

8、,表示状态转移,可分为同步与异步复位。同步:always@(posedgeclk)if(!reset)…………异步:always@(posedgeclkornegedgereset)if(!reset)…………组合逻辑用case语句,sensitivelist包括当然状态(currentstate)和输入(a,b,c…)。对于状态机的输出可以通过寄存器寄存一下,消除毛刺,

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。