Verilog语法遗漏点
1 关于参数定义
Parameter:parameter只能定义在端口生命的前面,如
Input[whith:0] a;
Parameter whith=4;
这样的参数定义出现在声明的后面会报错
2 关于always块
always块不仅可以描述时序逻辑,也可以描述组合逻辑
如wire a,b; assign a=b
与reg a; wire b; always@(b) a=b; 可见,always块内允许阻塞赋值
不过需要注意的是
always中,等号左边的变量必须是reg型,而不能是wire型,无论是组合逻辑还是时序逻辑均成立,但是最终变量a被综合成了连线,而不是寄存器!!!!
3 关于if else
If…else…语句,只能依附于always等程序模块不能单独使用,如果想单独使用,用三目运算符代替
4 不定态X表示不可推断电平,高阻态Z相当于断路状态
5 REG型量不一定被综合成寄存器
Verilog中,块内被赋值的变量,都必须是寄存器reg类型!!如上述2中的介绍,但是reg型变量不一定被综合成寄存器,组合逻辑中被综合成互连,不完全组合逻辑中,描述成锁存器。所以寄存器变量不一定被综合成寄存器。
6 归约运算符
归约运算符是一种单目运算符;被操作数具有一定的位宽,操作的结果都是1位。
如wire[3:0]bus 4’hf;
Wire result = &bus;
上述赋值相当于assign result=bus[0]&bus[1]&bus[2]&bus[3];//归约与运算符
如果是|,相当于assign result bus[0]| bus[1]|bus[2]|bus[3];//归约或运算符
如果是^,相当于………………………………………………………………..//归约异或运算符
7 实例参数重载方式,这个是为了输入端口宽度进行灵活配置的方式(遇到再看)
8 关于alwaya@()敏感列表
Always@(posedge clk)
Always@(signal)
关于电平敏感,表示电平发生变化就执行块内的内容。
Verilog语法遗漏点的更多相关文章
- Verilog语法基础讲解之参数化设计
		Verilog语法基础讲解之参数化设计 在Verilog语法中,可以实现参数化设计.所谓参数化设计,就是在一个功能模块中,对于一个常量,其值在不同的应用场合需要设置为不同的置,则将此值在设计时使用 ... 
- verilog语法实例学习(4)
		Verilog模块 Verilog中代码描述的电路叫模块,模块具有以下的结构: module module_name[ (portname {, portname})]; //端口列表 [parame ... 
- verilog语法实例学习(1)
		本文档中通过verilog实例来学习verilog语法.Verilog是一种硬件描述语言,它具有并发性和时序性.并发性是指不同硬件模块的同时操作,时序性是指信号的赋值或操作在时钟的边沿进行.由于作者本 ... 
- verilog语法学习目录
		verilog语法实例学习(1) Verilog中的注释 Verilog中的信号 标识符 信号的值 Verilog中的数字 Verilog中的参数 verilog语法实例学习(2) 线网类型 变量类型 ... 
- 跟着我从零开始入门FPGA(一周入门XXOO系列)-1、Verilog语法
		(本连载共七部分,这是第一部分) 作者:McuPlayer2013 (EETOP FPGA版块版主) 原帖地址:http://bbs.eetop.cn/thread-385362-1-1.html ... 
- verilog语法实例学习(12)
		verilog中的综合和不可综合总结 Verilog中综合的概念 综合就是EDA工具或者说综合工具把我们编写的verilog代码转化成具体电路的过程.Verilog中有很多语法,结构,过程,语句,有些 ... 
- verilog语法实例学习(6)
		函数和任务 函数 https://wenku.baidu.com/view/d31d1ba8dd3383c4bb4cd283.html verilog中函数的目的是允许代码写成模块的方式而不是定义独立 ... 
- verilog语法实例学习(5)
		子电路模块 子电路模块的使用 一个verilog模块能够作为一个子电路包含在另一个模块中.采用这种方式,所有的模块都必须定义在一个文件中,那么verilog编译器就必须被告知每个模块的所属.模块例化的 ... 
- verilog语法实例学习(2)
		Verilog中的信号类型 线网类型 线网类型表示一个或多个门或者其它类型的信号源驱动的硬件连线.如果没有驱动源,则线网的默认值为z.verilog中定义的线网类型有以下几种: wire,tr ... 
随机推荐
- mssql sqlserver 获取指定日期为本月第几个工作日
			转自:http://www.maomao365.com/?p=6771 摘要: 下文讲述工作中,需要获取指定日期在当月的工作日 下文讲述常规的指定工作日所在月的天数分析,实现思路:1 生成一个国家法定 ... 
- spring-AOP(面向切面编程)-xml方式配置
			AOP是针对面向对象编程的一种补充,有时使用面向对象不能很好完成一些额外的功能业务时,可以采用AOP来进行补充. AOP术语: 切面(Aspect) 切面是用于编写切面逻辑的一个类,这个类很类似于JD ... 
- iis 6,7 ftp 进行用户隔离进行权限控制,不同用户查看不同文件夹
			iis 6 配置点击链接 http://www.jb51.net/article/20676.htm iis 7配置 1.建立文件夹 C:\ftp, 并增加 目录 localuser(这个是必须的名字 ... 
- python scapy的用法之ARP主机扫描和ARP欺骗
			python scapy的用法之ARP主机扫描和ARP欺骗 目录: 1.scapy介绍 2.安装scapy 3.scapy常用 4.ARP主机扫描 5.ARP欺骗 一.scapy介绍 scapy是一个 ... 
- Tomcat结构
			Tomcat结构 Server(服务器) 服务器代表整个Tomcat容器. Tomcat提供了服务器接口的默认实现(很少由用户定制). Service(服务) 服务是位于服务器内部的中间组件,将一个或 ... 
- 让ie8支持 placeholder 属性
			一. ie8支持 placeholder 属性 /* * ie8支持 placeholder 属性 */ $(function(){ if( !('placeholder' in document. ... 
- HTTP Health Checks
			This article describes how to configure and use HTTP health checks in NGINX Plus and open source NGI ... 
- JSX格式化代码,你值得拥有!
			ext install prettier-vscode https://segmentfault.com/q/1010000014822745 
- postgreSQL 应用case when的例子
			selectname,md5(indvl_id_nbr) as indvl_id_nbr,case when char_length(indvl_id_nbr)=18 or char_length(i ... 
- win10 搭建virtualenvwrapper虚拟环境
			1. 安装virtualenvwrapper pip install virtualenvwrapper-win 注: linux下运行pip install virtualenvwrapper 2. ... 
