verilog小结

1B4AAP346HJXSA9EWKU942M82
是看一份资料小结的,图传不上来,以后能有个人空间了再传吧,(北航夏宇闻的书不错)。


一:基本
Verilog中的变量有线网类型和寄存器类型。线网型变量综合成wire,而寄存器可能综合成WIRE,锁存器和触发器。


二:verilog语句结构到门级的映射
1、连续性赋值:assign
连续性赋值语句逻辑结构上就是将等式右边的驱动左边的结点。因些连续性赋值的目标结点总是综合成由组合逻辑驱动的结点。Assign语句中的延时综合时都将忽视。


2、过程性赋值:
过程性赋值只出现在always语句中。


阻塞赋值和非阻塞赋值就该赋值本身是没有区别的,只是对后面的语句有不同的影响。


建议设计组合逻辑电路时用阻塞赋值,设计时序电路时用非阻塞赋值。


过程性赋值的赋值对象有可能综合成wire,latch,和flip-flop,取决于具体状况。如,时钟控制下的非阻塞赋值综合成flip-flop。


过程性赋值语句中的任何延时在综合时都将忽略。


建议同一个变量单一地使用阻塞或者非阻塞赋值。


3、逻辑操作符:
逻辑操作符对应于硬件中已有的逻辑门


4、算术操作符:
Verilog中将reg视为无符号数,而integer视为有符号数。因此,进行有符号操作时使用integer,使用无符号操作时使用reg。


5、进位:
通常会将进行运算操作的结果比原操作数扩展一位,用来存放进位或者借位。如:
Wire [3:0] A,B;
Wire [4:0] C;
Assign C=A+B;
C的最高位用来存放进位。


6、关系运算符:
关系运算符:<,>,<=,>=
和算术操作符一样,可以进行有符号和无符号运算,取决于数据类型是reg ,net还是integer。


7、相等运算符:==,!=
注意:===和!==是不可综合的。
可以进行有符号或无符号操作,取决于数据类型


8、移位运算符:
左移,右移,右边操作数可以是常数或者是变量,二者综合出来的结果不同。


9、部分选择:
部分选择索引必须是常量。


10、BIT选择:
BIT选择中的索引可以用变量,这样将综合成多路(复用)器。
11、敏感表:
Always过程中,所有被读取的数据,即等号右边的变量都要应放在敏感表中,不然,综合时不能正确地映射到所用的门。


12、IF:
如果变量没有在IF语句的每个分支中进行赋值,将会产生latch。如果IF语句中产生了latch,则IF的条件中最好不要用到算术操作。Case语句类似。Case的条款可以是变量。


如果一个变量在同一个IF条件分支中先赎值然后读取,则不会产生latch。如果先读取,后赎值,则会产生latch。


13、循环:
只有for-loop语句是可以综合的。


14、设计时序电路时,建议变量在always语句中赋值,而在该always语句外使用,使综合时能准确地匹配。建议不要使用局部变量。


15、不能在多个always块中对同一个变量赎值


16、函数
函数代表一个组合逻辑,所有内部定义的变量都是临时的,这些变量综合后为wire。


17、任务:
任务可能是组合逻辑或者时序逻辑,取决于何种情况下调用任务。


18、Z:
Z会综合成一个三态门,必须在条件语句中赋值


19、参数化设计:
优点:参数可重载,不需要多次定义模块


四:模块优化
1、资源共享:
当进程涉及到共用ALU时,要考虑资源分配问题。可以共享的操作符主要有:关系操作符、加减乘除操作符。通常乘和加不共用ALU,乘除通常在其内部共用。


2、共用表达式:
如:C=A+B;
D=G+(A+B);
两者虽然有共用的A+B,但是有些综合工具不能识别.可以将第二句改为:D=G+C;这样只需两个加法器.


3、转移代码:
如循环语句中没有发生变化的语句移出循环.


4、避免latch:
两种方法:1、在每一个IF分支中对变量赋值。2、在每一个IF语句中都对变量赋初值。


5:模块:
综合生成的存储器如ROM或RAM不是一种好方法。最好用库自带的存储器模块。


五、验证:
1、敏感表:
在always语句中,如果敏感表不含时钟,最好将所有的被读取的信号都放在敏感表中。


2、异步复位:
建议不要在异步时对变量读取,即异步复位时,对信号赎以常数值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/243248.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

google G1,G2,G3比较(YY)

其实G1,G2,G3的主要不同点有以下几个&#xff1a; 1、CPUG1,G2都是Qualcomm MSM7201A 528 MHzG3是Qualcomm MSM7200A 528 MHz 应该说7201A出的时间比7200要晚一些&#xff0c;主频一样&#xff0c;可是功能上略低于7200&#xff08;执行效率是一样的&#xff09;根…

天才静之

木心说&#xff1a;“最高一层天才&#xff0c;是早熟而晚成的。”我一直认为静之就是一个天才。天才不同于才子&#xff0c;才子早熟&#xff0c;但往往短命&#xff0c;而静之却常胜不衰&#xff0c;愈“老”弥坚。 从诗歌、散文到小说&#xff0c;从电视剧、电影再到话剧、歌…

改进的case语句

改进的case语句 SystemVerilog为case、casex和casez的判断提供了专门的unique和priority修饰符。这些修饰需放在关键字case、casex和casez前面。 unique case(<case_expression>)...//条件选项 endcasepriority case(<case_expression>)...//条件选项 endcase1、…

verilog经验谈

规范很重要工作过的朋友肯定知道&#xff0c;公司里是很强调规范的&#xff0c;特别是对于大的设计&#xff08;无论软件还是硬件&#xff09;&#xff0c;不按照规范走几乎是不可实现的。逻辑设计也是这样&#xff1a;如果不按规范做的话&#xff0c;过一个月后调试时发现有错…

priority case语句

priority case语句 一个priority case可能具有多个条件选项匹配 priority case语句指定&#xff1a; 至少有一个条件选项的值与条件表达式匹配如果有多个条件选项的值与条件表达式匹配&#xff0c;必须执行第一个匹配分支 修饰符priority表示设计者认为两个或多个条件选择表…

Windows Mobile logo测试介绍

首先声明本文转自&#xff1a;http://softtest.chinaitlab.com/sji/744369.html 一、Windows Mobile简介 Windows Mobile是微软主要针对手机市场而推出的一种操作系统&#xff0c;改系统和Nokia Sybian系统一样把手机推向了智能化。丰富的功能以及强大的品牌优势让这一系统逐渐…

Scroll Dialog

类似CScrollView的CDialog类 http://download.csdn.net/detail/hemmingway/7119551

“象征界”的奇观:刘天怜花鸟工笔作品印象

有人说&#xff1a;“创新”是西洋画的基调&#xff0c;中国画的焦点是“承传”。就是说&#xff0c;西画必须花样翻新&#xff0c;挑战前人&#xff0c;甚至要推倒重来&#xff0c;唯此才可能在艺术史上占有一席之地&#xff1b;中国画强调以古人为师&#xff0c;重视师徒之间…

改进的if...else判断语句

改进的if…else判断语句 SystemVerilog的判断修饰符unique和priority可以和if…else一起使用。使用这些修饰符不仅可以减少此类判断语句的不确定性&#xff0c;还可以在建模早期发现潜在的设计错误。 1、unique if…else判断语句 unique if…else可以并行求值 修饰符unique表示…

FPGA的IP核

http://blog.sina.com.cn/s/blog_5f6fcfce01012w4g.html IP核概述 利用IP核设计 电子系统 &#xff0c;引用方便&#xff0c;修改基本元件的功能容易。具有复杂功能和商业价值的IP核一般具有知识产权&#xff0c;尽管IP核的市场活动还不规范&#xff0c;但是仍有许多 集成电路…

亚马逊正式发布关系型数据库Amazon Aurora

在去年的AWS re:Invent大会上&#xff0c;亚马逊宣布了Amazon Aurora。Aurora是一个关系型数据库&#xff0c;可以跨3个可用区域复制6份数据&#xff0c;其设计目标是提供高性能和高可用性&#xff08;99.99%&#xff09;&#xff0c;并且存储可以轻松高效地扩展到64TB。近日&a…

刘小东的“空城记”

刘小东的“空城记” 。从“三峡移民”到“金城小子”&#xff0c;从“温床”&#xff0c;再到"新疆和田 ”,今天&#xff0c;刘小东又把“鄂尔多斯” 纳入自己介入现实的创作计划。鄂尔多斯&#xff0c;一个中国曾经最贫瘠的所在&#xff0c;因为矿产开发&#xff0c;迅…

鼠标键盘驱动分析

link: http://blog.21ic.com/user1/5585/archives/2009/59432.html

有限状态机建模

有限状态机建模 1、使用枚举类型建立状态机模型 枚举类型有固定的数值 枚举类型提供了一种定义一个具有有限合法数值集合的变量的方法。数值是用标签而不是数字逻辑值表示的。 枚举类型支持抽象FSM类型 枚举类型支持更高抽象层次的建模&#xff0c;并且能描述精确的、可综合的…

时钟周期及秒(s) 毫秒(ms) 微秒(μs) 纳秒(ns) 皮秒(ps)之间转换

1秒1000毫秒(ms) 1毫秒1&#xff0f;1,000秒(s) 1秒1,000,000 微秒(μs) 1微秒1&#xff0f;1,000,000秒(s) 1秒1,000,000,000 纳秒(ns) 1纳秒1&#xff0f;1,000,000,000秒(s) 1秒1,000,000,000,000 皮秒(ps) 1皮秒1&#xff0f;1,000,000,000,000秒(s)

聆听南音

北京。半木空间。聆听南音古曲。 南音亦称弦管、南乐。起于晋唐&#xff0c;盛于南宋&#xff0c;至今流传于泉州闽南地区。被誉为“中国音乐史上的活化石” 。今晚&#xff0c;南音传人蔡雅艺率三位南音大师现场演出、宣讲并与"半木"品牌创始人吕永中先生对话交流…

不是每个人都适合linux

开源特性 Copyleft意味着&#xff0c;linux用户要学会一定程度的DIY。这不仅仅是说&#xff0c;你需要一些预备知识才可以开始。这包含的另一层意思是&#xff0c;在出现了问题的时候&#xff0c;用户很可能并不会得到及时有效的外来援助。   开源社区发布的内容通常是主题比…

WinCE中的paging pool

我们知道&#xff0c;在Config.bib配置中&#xff0c;RAM指定的内存区域会被划分为程序内存和对象存储。但在使用paging pool时&#xff0c;RAM段要减去paging pool的大小&#xff0c;剩余空间再划分为程序内存和对象存储。其中程序内存主要为正在运行的程序保存堆和栈的内容。…

在FSM模型中使用两态数据类型

在FSM模型中使用两态数据类型 1、使用两态类型和枚举类型对FSM复位 在仿真刚开始时&#xff0c;四态数据类型的值是逻辑X。类似有限状态机这样的模型中&#xff0c;四态变量的X逻辑值可以用来表示模型还没有复位&#xff0c;或复位逻辑的建模不正确。 仿真刚开始时&#xff0c…

没有建立对验证码签名的目录的发布者信任

在Windows 7下安装 FX3 USB驱动&#xff0c;一直提示 “没有建立对验证码签名的目录的发布者信任” 导致无法安装驱动&#xff0c;后来测试很多的方法&#xff0c;包括复制 inf 和sys文件到相应的 C:\windows\inf 与 C:\windows\system32\driver 目录下&#xff0c;设置 IE浏览…