不同verilog代码的RTL视图.doc

不同verilog代码的RTL视图.doc

ID:27826921

大小:52.50 KB

页数:3页

时间:2018-12-06

不同verilog代码的RTL视图.doc_第1页
不同verilog代码的RTL视图.doc_第2页
不同verilog代码的RTL视图.doc_第3页
资源描述:

《不同verilog代码的RTL视图.doc》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、不同verilog代码的RTL视图  刚开始玩CPLD/FPGA开发板的时候使用的一块基于EPM240T100的板子,alter的这块芯片虽说功耗小体积小,但是资源还是很小的,你写点稍微复杂的程序,如果不注意codingstyle,很容易就溢出了。当时做一个三位数的解码基本就让我苦死了,对codingstyle的重要性也算是有一个比较深刻的认识了。  后来因为一直在玩xilinx的spartan3xc3s400,这块芯片资源相当丰富,甚至于我在它里面缓存了一帧640*480*3/8BYTE的数据都没有问题(VGA显示用

2、)。而最近接触EPM7128,它的资源似乎也不丰富,我写着写着有时不注意就无法布线了。由此可见codingstyle对设计的重要性,尤其是在资源紧张或者速度要求较高的设计中。我个人对前者的体会深一些,高速的设计没有涉及过,只是明白一些用流水线提高速度的方法。  可以步入正题了,先拿一段简单的代码开始吧。我先提一点,这回我用的是quartusII7.0进行测试,其它的EDA工具综合出来的RTL视图可能会不一样,所以仅作为在quartusII7.0环境下的一些参考吧。不过思路是一样的,可以借鉴的。  Ex1:  input

3、[1:0]xin;  outputdout;  assigndout=(xin==2’b0);  代码很简单,就是当xin==2’b0时dout=1,否则dout=0。上面这段程序的RTL视图如下:    其实就是一个比较器,如果xin=2’h0,那么输出OUT就为1。和设想一样。  下面是我在参考一些别人的代码的时候看到别人一种常见的写法,它是用了?语句。  input[1:0]xin;  outputdout;  assigndout=(xin==2’b0)?1’b1:1’b0;  RTL如下:    是不是发现多

4、了以一个选择器(可能不叫选择器吧,但是你明白意思就可以),这样平白无故的就多耗用了一点资源,刚开始的时候我也是傻乎乎的跟着别人用这种写法,但是看到RTL视图后我就不这么干了,既然前者一样可以得到预期结果,为什么我还要画蛇添足多一个选择器呢。所以,推荐使用前者。资源的节约是潜移默化的~_~  (先说一点吧,其它的待我想起或者是感悟到了再提吧,以上也完全是我的个人愚见,如有不妥之处欢迎拍砖~_~)

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

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

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