【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】

这篇具有很好参考价值的文章主要介绍了【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Verilog 模块的基本概念

下面先介绍几个简单的Verilog HDL程序,从中了解Verilog模块的特性。
例1 如图所示的二选一多路选择器的Verilog HDL程序如下:

module muxtwo (out, a,b,sl);
		input a,b,sl;
		output out;
		reg out;
				always @ (sl or a or b)
						if(! sl) out = a;
						else out = b;
endmodule

从例1中很容易理解模块muxtwo的作用。它是一个如图所示的二选一多路器,输出out与输入a一致,还是与输入b一致,由sl的电平决定。当控制信号sl为非(低电平0)时,输出out与输入a相同,否则与b相同。always @ (sl or a or b)表示只要sl 或a 或b,其中若有一个变化时就执行下面的语句。人们并不关心它的电路结构,关心的是如何从逻辑功能上来描述它。Verilog的语法支持这种逻辑行为的描述。
【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】
为了实现这个电路的逻辑功能,也能用布尔表达式来描述,Verilog语言中,可以用“~”、“&”、“|”操作符分别表示:求反、相与和相或运算操作。所以例1的muxtwo模块实现的逻辑功能也能用例2形式的Verilog代码来表示。
例2 如图所示的带有与非门的二选一多路选择器的Verilog HDL程序如下:

module muxtwo (out, a,b,sl);
		input a,b,sl;  //输入信号名
		output out;  //输出信号名
		wire nsl, sela, selb;  //定义内部连接线
		assign nsl =~ sl;  //求反
		assign sela = a&nsl; //按位与运算
		assign selb = b&.sl;
		assign out = sela | selb;  //按位或运算
endmodule

【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】
上面例子中实现的逻辑功能是非常易理解的,它从本质上就是一个逻辑表示式,表达的是一个二选一多路选择器,如例3所示
例3 如图所示的多路选择器的Verilog HDL程序如下:

module muxtwo (out, a,b,sl);
		input a,b,sl;  //输入信号名
		output out;  //输出信号名
		not				u1(nsl,sl);
		annd	#1	u2(sela,a,nsl);
		and		#1	u3(selb,b,sl);
		or			#1 	u4(out,sela,selb);
endmodule

【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】

从图中很容易理解模块muxtwo的作用。它也是一个二选一多路器,输出out与输入a一致,还是与输入b一致,由sl的电平决定。当控制信号sl为非(!)(低电平0),输出out与输入a相同,否则与b相同。模块的描述用基本的与门、或门和非门的互联来描述。在程序模块中出现的and、or和not都是Verilog语言的保留字,由Verilog语言的原语(primitive)规定了它们的接口顺序和用法,分别表示与门、或门和非门,其中元件的输出口都规定在第一个端口,#1和#2分别表示门输入到输出的延迟为1和2个单位时间;模块程序中的u1、u2、u3、u4与逻辑图中的逻辑元件对应,表示逻辑元件的实例名称。模块表示的是电路结构,跟程序右面的电路逻辑图表示完全一致的。Verilog的语法也支持这种基于逻辑单元互联结构的描述。
如果在编写Verilog模块时,不但符合语法,还符合一些基本规则,就可以通过计算机上运行的工具把例1通过例2的中间形式自动转换为例3形式的模块,这个过程叫做综合。我们知道例3模块很容易与某种工艺的基本元件逐一对应起来,再通过布局布线工具自动地转变为某种具体工艺的电路布线结构。在第一部分里除了讲解基本语法外,主要讲解符合何种风格的Verilog模块是可以综合的;何种风格的模块是不可以综合的;不可综合的Verilog模块有些什么作用等。
下面再看几个简单的模块,目的是初步了解Verilog语法最重要的几个基本概念:并行性、层次结构性,并了解测试平台(testbench).
例4 通过连续赋值语句描述一个3位加法器的Verilog HDL程序如下:

module adder( count, sum, a, b,cin);
		input[2:0] a,b;
		input cin;
		output count;
		output[2:0] sum;
		assign {count,sum} = a+b+cin;
endmodule

这个例子通过连续赋值语句描述了一个名为adder的3位加法器。它可以根据两个3比特数a、b和进位(cin)计算出和(sum)及向上进位(count)。从例子中可以看出整个Verilog HDL程序是位于module和endmodule声明语句之间的。
例5 通过连续赋值语句描述一个比较器的Verilog HDL程序如下:

module compare(equal,a,b);
		output equal;   //声明输出信号equal
		input[1:0] a,b;   //声明输入信号a,b
		assign equal = (a==b) ? 1:0;
		/*如果a,b两个输入信号相等,输出为1;否则为0*/
endmodule

此程序通过连续赋值语句描述了一个名为compare的比较器。对2比特数a、b进行比较,如a与b相等则输出equal为高电平,否则为低电平。在这个程序中,/*……*/和//……表示注释部分。注释只是为了方便程序员理解程序,对编译是不起作用的。
例6 如图所示的三态门选择器的Verilog HDL程序如下:

module trist2(out,in,enable);
		output out;
		input in,enable;
		bufif1 mybuf(out,in,enable);
endmodule

【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】

该程序描述了一个名为trist2的三态驱动器。程序通过调用一个在Verilog语言提供的原语(primitive)库中现存的三态驱动器元件bufif1来实现其逻辑功能。在trist2模块中所用到的三态驱动器元件bufif1的具体名字叫做mybuf,这种引用现成元件或模块的方法叫做实例化或实例引用,这表示电路构造的一种常用的语法现象。
例7 采用二个模块的三态门选择器的Verilog HDL程序如下:

`module trist1(sout,sin,ena);
		output sout;
		input sin,ena;
		mytri tri_inst(.out(sout),.in(sin),.enable(ena));
		//引用由mytri模块定义的实例元件tri_inst
endmodule
module mytri(out,in,enable);
		output out;
		input in,enable;
		assign out=enable ? in:'bz;
endmodule

该程序通过另一种方法描述了一个三态门。在这个例子中存在着两个模块:模块trist1引用由模块mytri定义的实例部件tri_inst,模块trist1是上层模块;模块mytri则被称为子模块。在实例部件tri_inst中,带“.”表示被引用模块的端口,名称必须与被引用模块mytri的端口定义一致,小括号中表示在本模块中与之连接的路线。
上面这些例子都是可以综合的,通过综合工具可以自动转换为由与门、或门和非门组成的加法器、比较器和三态门等组合逻辑。在数字电路基础中已经学习过怎样用组合逻辑来实现1位或2位整数的加法和比较,而带超前进位链的多位整数加法器和多位比较器的逻辑图相当复杂,很难即时辨明。但这些也是已经成熟的电路结构,对千计算机支持的EDA工具来 说这只是一个映射的过程,系统设计人员就不必过于关心它们逻辑构成的细节,而把主要精力集中在系统结构的考虑上,从而大大提高了设计效率。

Verilog用于模块的测试

Verilog还可以用来描述变化的测试信号。描述测试信号的变化和测试过程的模块也叫做测试平台(testbench或testfixture),它可以对上面介绍的电路模块(无论是行为的或结构的)进行动态的全面测试。通过观测被测试模块的输出信号是否符合要求,可以调试和验证逻辑系统的设计和结构正确与否,并发现问题及时修改。图2.5为Verilog时用于模块测试的原理图。
【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】
下面来看一个Verilog的测试模块,它可以对[例1]和[例2]和[例3]的多路器模块进行逐步深入的全面测试。
例8 对[例1]~[例3]多路器模块的Verilog HDL程序如下:

`include"muxtwo.v"
		module t;
			reg ain,bin,select;
			reg clock;
			wire outw;
			initial      //把寄存器变量初始化为一确定值
			begin
				ain =0;
				bin  =0;
				select = 0;
				clock = 0;
			end
			always #50 clock =~clock;  //产生一个不断重复地周期为100个地时钟信号clock
			always @ (posedge clock)
				begin   //{$random}为系统任务,会产生一个随机数
					#1 ain = {$ random} %2;  //产生随机地位信号流ain 和bin, %2为模2运算
					#3 bin = {$ random} %2; //分别延迟1和3个时间单位后产生随机地位信号流ain 和 bin
				end
				always #1000	select = ! select;  //产生周期为10000个单位时间的选通信号变化
				//···················
				muxtwo m(.out(outw), .a(ain), .b(bin), .sl(select));
				/*实例引用多路器,并加入测试信号流,以观察模块的输出out。其中,muxtwo是已经定义的(行为的或结构的)模块,m表示在本测试模块中有一个名为m的muxtwo的模块,其四个端口分别为:
				.out(), .a(), .b(), .sl(),
				"."表示端口;后面紧跟端口名,其名称必须与muxtwo模块定义的端口名一致;小括号内的信号名为与该端口连接的信号线名,可以用别的名,但必须在本模块中定义,说明其类型。*/
endmodule

其中 muxtwo 可以是行为模块,也可以是布尔逻辑表达式或门级结构模块。 模块 t 可以 对 muxtwo模块进行逐步深入的完整测试。 这种测试可以在功能(即行为)级上进行,也可以在逻辑网表(逻辑布尔表达式)和门级结构级上进行。 它的分别称为前(RTL)仿真、逻辑网表仿真和门级仿真。 如果门级结构模块与具体的工艺技术对应起来,并加上布局布线引入的延迟模型 ,此时进行的仿真称为布线后仿真,这种仿真与实际电路情况非常接近。 可以通过运行 仿真器 ,并观察输人/输出波形图来分析设计的电路模块的运行是否正确。文章来源地址https://www.toymoban.com/news/detail-404718.html

到了这里,关于【Verilog数字系统设计(夏宇闻)4-----Verilog语法的基本概念2】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Verilog数字系统设计——带进位的8位加法器

    试分别使用门级原语和always 语句设计带进位的8位加法器,要求编制测试模块对实现的逻辑功能进行完整的测试; 使用门级原语设计时注意先在草稿上做出该加法器的门级设计; 如有余力可以进一步使用门级原语设计出带超前进位链的8位加法器(期末有加分); 实验提交

    2024年02月15日
    浏览(48)
  • verilog数字系统设计教程(夏闻宇)|第一章-第六章

    早听闻此书大名,虽然有些verilog的编程经验,今天来系统的学习下verilog,完善知识体系,提升编程能力。本文章只当自己做笔记使用,记录自己没掌握的重难点,和大家一起学习。 目录 第一章  第二章 verilog语法 第三章 模块的结构、数据类型、变量和基本运算符号 1.常量

    2024年03月18日
    浏览(44)
  • Verilog数字系统设计——10进制计数器,具有异步复位功能

    编程实现10进制计数器,具有异步复位功能,十位和个位用8421BCD码表示,各端口定义如下图所示: 仔细考虑端口定义中每个端口的含义; 要求完成程序编辑、编译、时序仿真; 实验提交Verilog设计文件(.v文件)、仿真波形截图以及对于第3个步骤所提出问题的回答,文件打包

    2024年02月11日
    浏览(36)
  • 数字系统设计实验七(完结):verilog实现简易饮料贩售机

    1.问题重述: 自动售饮料机是一个典型的利用状态机进行电路设计的例子。要求采用有限状态机设计,使用case语句来描述各个状态之间的转移关系。假定每瓶饮料售价为2.5元,可使用 2 种硬市,即5角(half_dollar)、1元(one_dollar),机器有找零功能。下图是该自动售饮料机的示

    2024年02月08日
    浏览(47)
  • Verilog基本语法之运算符(三)

    运算符按功能分为9类: 算术运算符 逻辑运算符 关系运算符 等式运算符 缩减运算符 条件运算符 位运算符 移位运算符 位拼接运算符 运算符按操作数的个数分为3类: 单目运算符:带一个操作数 逻辑非!,按位取反~,缩减运算符,移位运算符 双目运算符:带两个操作数 算

    2023年04月09日
    浏览(41)
  • 【FPGA入门】第一篇、Verilog基本语法常识

    目录 第一部分、不同的变量类型 1、wire和reg的区别  2、如何对变量进行赋值呢? 3、什么是阻塞?什么是非阻塞? 第二部分、变量位宽的定义 1、各种系统默认情况 2、变量位宽声明方式 3、表明位宽的情况下,赋值方式 4、两个模块之间例化,不定义变量直接用的方式 5、常

    2024年02月04日
    浏览(50)
  • verilog 从入门到看得懂---verilog 的基本语法数据和运算

            笔者之前主要是使用c语言和matab 进行编程,从2024年年初开始接触verilog,通过了一周的学习,基本上对verilog 的语法有了基本认知。总统来说,verilog 的语法还是很简单的,主要难点是verilog是并行运行,并且强烈和硬件实际电路相关,在设计到的时候需要考虑时序

    2024年03月18日
    浏览(47)
  • 基于FPGA的数字电子琴——数电小系统设计【数字电子技术】(使用Vivado中的verilog语言)含piano代码文件(全)

    目录 一、电路功能描述 二、方案设计 1. 总体设计方案 2. 对原理框图或程序流程图做出简单解释 3. 各模块介绍 3.1 音频驱动模块 3.2 LED显示模块 3.3 数码管显示模块 3.4 矩阵键盘模块 3.5 PS2机械键盘模块 3.6 时钟分频模块 3.7 曲谱生成模块 三、总结 数码管和LED显示模块 矩阵键盘

    2024年02月06日
    浏览(53)
  • 系统架构设计师笔记第16期:数据库基本概念

    数据库技术在过去几十年中经历了显著的发展和演变。 层次数据库和网状数据库:20世纪60年代和70年代初,层次数据库和网状数据库是主流的数据库模型。层次数据库使用树状结构组织数据,而网状数据库使用复杂的网络结构。这些数据库模型适用于特定的数据组织和查询需

    2024年02月09日
    浏览(50)
  • Go语言的基本概念与语法

    每个 Go 程序都是由包组成的. 程序从 main 包开始运行. 本程序通过导入路径 \\\"fmt\\\" and \\\"math/rand\\\" 来使用这两个包. 按照约定,包名与导入路径的最后一个元素相同。例如, \\\"math/rand\\\" 包中的源码均以 package rand` 语句开始. 注意: 执行这些程序的环境是确定性的 所以每次运行示例程序

    2024年02月11日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包