VerilogHDL数字系统设计及实践第章Verilog行为描述
Verilog HDL数字系统设计 原理 实例及仿真 第1章
图1.2 自上而下(Top-Do: (1) 这是一种模块化的设计方法; (2) 由于高层设计同器件无关,可以完全独立于目标器件 的结构,因此在设计的最初阶段,设计人员可以不受芯片结 构的约束,集中精力对产品进行最适应市场需求的设计,从 而避免了传统设计方法中的再设计风险,缩短了产品的上市 周期; (3) 由于系统采用硬件描述语言进行设计,可以完全独立 于目标器件的结构,因此设计易于在各种集成电路工艺或可 编程器件之间移植; (4) 多个设计者可同时进行设计; (5) 具有强大的系统建模、电路仿真功能;
9
设计周期长
设计周期短
1.1.3 EDA的开发过程 基于EDA的电子设计流程如图1.3所示。
图1.3 EDA工程设计流程
1.文本编辑/原理图编辑输入与修改 2.逻辑综合和优化 3.行为仿真 4.目标器件的布线/适配 5.功能仿真和时序仿真 6.目标器件的编程/下载 7.硬件仿真与测试
1.2 可 编 程 器 件
1.1.2 EDA与传统电子设计方法的比较 随着EDA技术的不断发展,其设计方法也发生着显著的
变化,已经从传统的自下而上的设计方法转变成自上而下的 设计方法。传统的电子设计方法是自下而上(Bottom-Up)的, 如图1.1所示,是基于电路板的设计。
图1.1 传统的电子设计方法
这种设计方法以固定功能元件为基础,然后根据这些器 件进行模块逻辑设计,完成各个模块后进行连接,最后形成 系统。这种手工设计方法的缺点如下:
EDA技术使设计者的工作可以仅限于利用软件的方式, 即利用硬件描述语言和EDA软件来完成对系统硬件功能的实 现,这是电子设计技术的一个巨大进步。另一方面,在现代 高新电子产品的设计和生产中,微电子技术和现代电子设计 技术是相互促进、相互推动又相互制约的两个环节,前者代 表了硬件电路物理层在广度和深度上的发展,后者则反映了 现代先进的电子理论、电子技术、仿真技术、设计工艺和设 计技术与最新的计算机软件技术有机的融合和升华。
verilog的三种描述方式
Verilog的三种描述方式Verilog是一种硬件描述语言(HDL),用于描述数字电路和系统。
它是一种高级语言,允许工程师以更高层次的抽象来描述电路,从而简化了电路设计和验证过程。
Verilog有三种主要的描述方式,分别是结构描述、行为描述和数据流描述。
本文将详细介绍这三种描述方式,并分析它们的特点和适用场景。
1. 结构描述结构描述是Verilog的一种描述方式,它通过层次结构和模块之间的连接关系来描述电路。
在结构描述中,我们可以使用模块、端口、电路连接和实例化等概念来描述电路的组成和连接方式。
结构描述类似于画出电路图,只需要关注电路的结构和连接关系,而不需要考虑电路的具体功能。
结构描述的语法如下所示:module ModuleName (input wire A, input wire B, output wire C);// 输入端口定义// 输出端口定义// 内部信号定义// 子模块实例化// 逻辑实现endmodule结构描述的特点是清晰明了,易于理解和调试。
通过模块化的设计和层次结构,可以方便地对电路进行分析和调试。
结构描述适用于需要详细描述电路结构和连接关系的场景,比如设计一个复杂的处理器或系统。
2. 行为描述行为描述是Verilog的另一种描述方式,它通过描述电路的功能和行为来实现对电路的描述。
行为描述使用类似于编程语言的语法,可以使用条件语句、循环语句和顺序语句等来描述电路的行为。
在行为描述中,我们可以直接使用Verilog的语法来描述电路的逻辑功能,而不需要关注电路的结构和连接关系。
行为描述的语法如下所示:module ModuleName (input wire A, input wire B, output wire C);// 输入端口定义// 输出端口定义// 内部信号定义// 逻辑实现always @ (A or B) begin// 行为描述endendmodule行为描述的特点是灵活性高,可以方便地实现复杂的逻辑功能。
精品课件-Verilog HDL数字系统设计-Verilog HDL数字系统设计-第1章
编程器件的基础上进一步发展的产物,它是作为ASIC领域中的 一种半定制电路而出现的,既解决了定制电路的不足,又克服 了原有可编程器件门电路有限的缺点。
第1章 概 述
26
如前所述,FPGA是由存放在片内的RAM来设置其工作状态的, 因此工作时需要对片内RAM进行编程。用户可根据不同的配置模 式,采用不同的编程方式。FPGA有如下几种配置模式:
第1章 概 述
1
第1章 概
述
1.1 EDA技术简介 1.2 可编程器件 1.3 Verilog HDL简介
第1章 概 述
2
1.1 EDA技术简介
现代电子设计技术的核心已日趋转向基于计算机的电子设 计自动化(EDA,Electronic Design Automation)技术。所谓 EDA技术,就是依赖功能强大的计算机,在EDA工具软件平台上, 对以硬件描述语言(HDL,Hardware Description Language)为 系统逻辑描述手段完成的设计文件,自动地进行逻辑编译、化 简、分割、综合、布局布线以及逻辑优化和仿真测试,直至实 现既定的电子线路系统功能。
6.目标器件的编程/下载 7.硬件仿真与测试
第1章 概 述
18
1.2 可 编 程 器 件
1.2.1 可编程逻辑器件概述 随着数字电路的普及,传统的定制数字集成电路器件已满
足不了应用的需求,可编程逻辑器件(PLD)应运而生,并逐渐地 成为主流产品。PLD与传统定制器件的主要区别是它的可编程性, 它的逻辑功能是由用户设计的,并且一般都可重复编程和擦除, 即PLD是能够为客户提供范围广泛的多种逻辑能力、特性、速度 和电压特性的标准成品部件,而且此类器件的功能可在任何时 间修改,从而实现多种不同的功能。对于可编程逻辑器件,设 计人员可利用价格低廉的软件工具快速开发、仿真和测试其设 计。
Verilog HDL数字设计实训教程第1章 Verilog HDL数字设计实训基础
图1-2 按键电路连接图和管脚对应图
1.1 实训平台
4个LED灯:
图1-3 LED电路连接图和管脚对应图
1.1 实训平台
2个数码管:
图1-4 数码管电路连接图和管脚对应图
1块液晶:
1.1 实训平台
图1-5 液晶电路连接图和管脚对应图
1个UART:
1.1 实训平台
图1-6 UART电路连接图和管脚对应图
if(p==N-1) begin p=0; clk_p=~clk_p; end else p=p+1; end always @(negedge clk) begin
if(q==N-1) q=0; else q=q+1;
if(p==(N-1)/2) clk_q=~clk_q; end assign clk_N=clk_p^clk_q; endmodule
图1-39 设置USB硬件端口
QuartusII设计流程
5.引脚锁定和硬件验证
图1-40 下载界面
QuartusII设计流程
5.引脚锁定和硬件验证
图1-41 选择下载文件
QuartusII设计流程
5.引脚锁定和硬件验证
图1-42 led灯闪烁的效果
1.3 分频器设计
分频器电路是非常有用的一种电路, 分频的方法很多,最常见的是利用加 法计数器对时钟信号进行分频。
begin if(p==N/2-1) begin p=0; clk_N=~clk_N; end else p=p+1;
end endmodule
图1-44 任意偶数分频仿真波形
1.3 分频器设计
【例1-5】 可设置参数的任意整数分频器:占空比可变。 module divf_parameter(rst,clk,en,clkout); input rst,clk,en; output clkout; integer temp; //最大值为2的32次方 parameter N=7,M=3; //N为分频系数,M/N为占空比 always @(posedge clk)
Verilog HDL数字设计教程(贺敬凯)第1章
路网表。
第1章 Verilog HDL数字设计综述
波形图输入方法则是将待设计的电路看成是一个黑盒子,
只需告诉EDA工具该黑盒子电路的输入和输出时序波形图,
EDA工具就可以完成黑盒子电路的设计。 原理图输入方法是一种类似于传统电子设计方法的原理 图编辑输入方式,即在EDA软件的图形编辑界面上绘制能完 成特定功能的电路原理图。原理图由逻辑器件(符号)和连接
理图和信号的连接表,如果是一个大的系统,将是一大摞图
纸,以后系统若出现问题,查找、修改起来都很麻烦。
第1章 Verilog HDL数字设计综述
上述过程是从底层开始,或在已有的功能模块的基础上 来搭建高层次的模块直至整个系统的。因此这种传统的电子 系统的设计过程是一种自底向上(Bottom-Up)的设计,设计 过程必须从存在的基本单元模块出发,基本单元模块必须是 已经设计成熟的标准单元模块或其他项目已开发好的单元模 块。
第1章 Verilog HDL数字设计综述
本书所有设计最终的实现目标主要定位于FPGA,因此下
面重点介绍FPGA的开发流程。FPGA的EDA开发流程如图1-3
所示。
第1章 Verilog HDL数字设计综述
图1-3 FPGA的EDA开发流程
第1章 Verilog HDL数字设计综述
从图1-3可以看出,FPGA的开发流程与图1-2所示的用 EDA工具设计数字系统的流程基本相同,都需要设计输入、 功能仿真、逻辑综合、布局布线(适配)、时序仿真、物理实 现等几个步骤。下面将分别介绍主要设计模块的功能特点。
第1章 Verilog HDL数字设计综述
1. 设计输入 在EDA软件平台上开发FPGA/CPLD时,首先要将电路系 统以一定的表达方式输入计算机。通常,EDA工具的设计输 入可分为以下两种类型:
数字系统设计初识Verilog HDL
(1)内置门级元件(逻辑门)
not and nand or nor xor xnor。(表8.1、8.2)
(2)内置开关级元件(三极管及储存节点等)
cmos nmos pmos。
(3)用户自己定义的模块。
22:32:11
门元件的调用
门元件调用格式:
门元件名字 <例化的门名字> (<端口列表>)
普通的门的端口列表顺序为: (输出,输入1,输入2,输入3,….); 例如: module AND_G2
input
A F B
(A,B,F)
A,B;
output F;
and G2(F,A,B);
endmodule
22:32:11
module rs_latch (y, yb, r, s); output y, yb; input r, s; nor n1( y, r, yb); nor n2( yb, s, y); endmodule
input A, B, Cin ; output Sum, Cout; reg Sum,Cout; reg T1,T2,T3; always @(A or B or Cin) begin Sum=(A^B)^Cin; T1=A&Cin; T2=B&Cin; T3=A&B; Cout=(T1| T2|T3); end endmodule //输入端口定义 //输出端口定义
endmodule
结果:具有低电平有效使能端的2-4译码器,输出为低电平有效。
22:32:11
总结:
用assign 连续赋值语句来描述一个组合逻辑电
路,关键是找出输出与输入之间的逻辑关系,写出
第1章 Verilog HDL入门简介
Verilog HDL数字系统设计及仿真
数字电路的回忆—七进制计数器
Verilog HDL数字系统设计及仿真
➢状态转换图
➢卡诺图
2
Verilog HDL数字系统设计及仿真
➢ Q3* 的卡诺图
➢状态方程:
Q3* Q3Q2 ' Q3 'Q2Q1
3
Verilog HDL数字系统设计及仿真
8
采用Verilog HDL代码
Verilog HDL数字系统设计及仿真
➢计数器模块
➢JK触发器模块
module
module JK_FF(J,K,CLK,Q,Qn);
Counter(Q3,Q2,Q1,C,CLK); input J,K;
output Q3,Q2,Q1,C;
input CLK;
input CLK;
output Q,Qn;
wire J1,K2,J3;
wire G3_n,G4_n,G5_n,G6_n,G7_n,G8_n;
nand G7(G7_n,Qn,J,CLK);
JK_FF JK1(Q1,Q1n,J1,1,CLK);nand G8(G8_n,CLK,K,Q);
JK_FF JK2(Q2, ,Q1,K2,CLK); nand G5(G5_n,G8_n,G6_n);
nand G1(Q,G3_n,Qn);
or or1(K2,Q1,Q3);
nand G2(Qn,Q,G4_n);
endmodule
not G9(CLK_n,CLK);
endmodule
9
Verilog HDL数字系统设计及仿真
➢更简洁的代码
module Counter(Q,CLK,RESET);
数字系统设计与Verilog HDL实验报告(二)
《数字系统设计与Verilog HDL》实验报告(二)班级:自动1003班姓名:**学号:********实验二、四位并串转换电路一、实验目的1、了解及掌握时序电路的基本结构常用数字电路;2、通过ModelSim软件编写时序电路的程序进行仿真和调试。
二、实验内容1、熟悉时序电路中时钟的同步与异步用法;2、编写一个四位并串转换设计程序以及测试该模块的测试程序,要求如下:(1)输入一个四位二进制数pin;(2)每个时钟周期按从左往右的顺序输出一位pin的二进制位的数。
三、实验步骤及源程序新建工程及文件,分别添加设计程序及测试程序,进行编译及纠错,编译通过后运行程序仿真进行调试得出结果。
设计模块:module para_to_serial4(pin,clk,reset,sout);input [3:0] pin;input clk,reset;output sout;reg sout;reg [3:0] data;always @(posedge clk or negedge reset)beginif(~reset)beginsout<=1'b0;data<=pin;endelsebegindata<={data[2:0],data[3]};sout<=data[3];endendendmodule测试模块:`timescale 1ns/1nsmodule test_para_to_ser;wire sout;reg [3:0] pin;reg clk,reset;para_to_serial4 test1(pin,clk,reset,sout);initialbeginclk=1'b0;reset=1'b0;#5 reset=1'b1;#300 $stop;endinitialpin=4'b1001;always#5 clk=~clk;endmodule四、实验结果五、实验心得体会这次试验相对于上次有了一定的难度,由于这门课程刚开始学习,我还不能很好地从宏观把握这门课程,对这门课程的认识和理解还不够深刻,所以做实验时遇到了一些困难,虽然找了一些参考资料,有一定的帮助,但最后还是有点纠结,最终在和同学的交流中才比较深刻的对实验有了了解。
Verilog HDL 数字系统设计及实践 第1章 Verilog层次化设计
1.3 Testbench的概念
// 添加激励 initial begin #0 A = 4'b0000; // 激励信号i_A初始值0 B = 4'b0000; // 激励信号i_B初始值0 Cin = 1'b0; // 激励信号i_Cin初始值0 #20 A = 4'b1111; // 20ns后,i_A值变为15 #20 B = 4'b0001; // 20ns后,i_B值变为1 #20 A = 4'b1110; // 20ns后,i_A值变为14 #20 Cin = 1'b1; // 20ns后,i_Cin值变为1 #10 $finish; // 结束仿真 end // 调用系统函数$monitor, 监视列表中的参数变化并显示 initial $monitor($time, " A:%d B:%d Cin:%d , sum:%d , carry:%d ", A, B, Cin, S, Cout); endmodule
o_S
o_S[3]
o_Cout
图1.1 四位全加器结构图
1.2 模块和端口
module exap (A,B,C); input A,B; output C; …… //逻辑功能描述 endmodule
A
exap
B
C
图1.2 模块和端口 一个模块的代码主要由 下面几个部分构成: 模块名定义、端口描述 和内部功能逻辑描述。 一个模块通常就是 一个电路单元器件
1.3 Testbench的概念
tb_fadder i_A i_B i_Cin i_A o_S i_B i_Cin fadder_4 o_Cout $monitor 显示
图1.6 tb_fadder结构
第4章-Verilog-HDL的描述方式
1.6 门的延时
可以使用门时延定义门从任何输入到其输出的信号传 输时延。门时延可以在门自身实例语句中定义。带有 时延定义的门实例语句的语法如下: gate_type [delay] [instance_name] (terminal_list) ;
时延规定了门时延,即从门的任意输入到输出的传输 时延。当没有强调门时延时,缺省的时延值为0。
[instance_name2] (term1, term2, ..., termN) , [instance_name3] (term1, term2, ..., termN), [instance_name4] (term1, term2, ..., termN) ;
1.2 多输入门
内置的多输入门包括: and nand nor or xor xnor 这些逻辑门只有单个输出, 1个或多个输入。门实例语句
pmos ( p类型MOS管)、nmos ( n类型MOS管),rnmos ( r代表电阻)和rpmos 开关有一个输出、一个输入和一个控制输入,例如: rnmos RN1 (ControlBit, ReadyBit, Hold) ;
cmos (mos互补)和rcmos (cmos的高阻态版本)开关有一个数据输出,一个 数据输入和两个控制输入。例如: (r)cmos [instance _name] (OutputA, InputB, NControl, PControl);
参考答案
module Parity_9_Bit(D,Even, Odd); input [0:8] D; output Even, Odd; xor
XE0(E0,D[0],D[1]), XE1(E1,D[2],D[3]), XE2(E2,D[4],D[5]), XE3(E3,D[6],D[7]), XF0(F0,E0,E1), XF1(F1,E2,E3), XH0(H0,F0,F1), XEVEN(Even,D[8], H0); not XODD(Odd,Even); endmodule
精品课件Verilog HDL数字设计教程-第1章 Verilog HDL数字设计综述
▪ 1.1 电子系统设计技术的发展 ▪ 1.2 数字系统典型设计流程 ▪ 1.3 HDL语言的发展、特点与应用 ▪ 1.4 Quartus II概述 ▪ 1.5 硬件描述语言的发展趋势 ▪ 1.6 小结
1.1 电子系统设计技术的发展 图1-1 理想的自顶向设计流程
1.2 数字系统典型设计流程
1.设计输入 2.综合 3.布线布局(适配) 4.仿真 5.下载和硬件测试
1.3 HDL语言的发展、特点与应用
常见的2种HDL语言: 1.Verilog HDL 2.VHDL
1.3 HDL语言的发展、特点与应用
系统级 算法级 寄存器传输级 逻辑门级 开关电路级
System Verilog
VHDL Verilog
VITAL
图 1-4 Verilog HDL与VHDL建模能力的比较
1.4 Quartus II概述
图形或 HDL编辑
Analysis & Synthesis (分析与综合)
设计 输入
综合或 编译
Filter (适配器)
Assembler (编程文件汇编)
Timing Analyzer (时序分析器)
作业
▪ P12 T1、2、3、4
每一种知识都需要努力, 都需要付出,感谢支持!
知识就是力量,感谢支持!
一一一一谢谢大家!!
1.2 数字系统典型设计流程
电路图 设计文件
HDL 设计文件
电路 功能仿真
Байду номын сангаас
N
Y
正确?
综合
HDL 功能仿真
N 正确?
Y
确定实现 电路的库
与实现逻辑的物理器件 有关的工艺技术文件
数字系统设计与Verilog_HDL(第4版)[王金明]第1章
IEEE标准
硬件描述语言与软件编程语言有本质的区别
综合(Synthesis)
将较高层次的设计描述自动转化为较低层次描述的过程
◆行为综合:从算法表示、行为描述转换到寄存器传输级
(RTL) ◆逻辑综合:RTL级描述转换到逻辑门级(包括触发器) ◆版图综合或结构综合:从逻辑门表示转换到版图表示,或 转换到PLD器件的配置网表表示
现代EDA技术的特征
(1)采用硬件描述语言(HDL)进行设计 (2)逻辑综合与优化 (3)开放性和标准化 (4)更完备的库(Library)
1.2 Top-down设计与IP核复用 1.2.1 Top-down设计 1.2.2 Bottom-up设计 1.2.3 IP复用技术与SOC
1.2.1 Top-down设计
EDA(Electronic Design Automation) 就是以计算机为工作平台,以EDA软件工具为开 发环境,以PLD器件或者ASIC专用集成电路为目 标器件设计实现电路系统的一种技术。 1.电子CAD(Computer Aided Design)
2.电子CAE(Computer Aided Engineering)
称为下载。
通常将对基于EEPROM工艺的非易失结构PLD器件
的下载称为编程(Program),将基于SRAM工艺
结构的PLD器件的下载称为配置(Configure)。
1.4 常用的EDA软件工具 集成的 FPGA/CPLD开发工具 逻辑综合器 仿真工具 其他设计工具
集成的FPGA/CPLD开发工具
SoC: SYSTEM on a CHIP
1.3 数字设计的流程
基于 FPGA/CPLD 的数字系统 设计流程
设计输入
Verilog硬件描述语言Verilog HDL设计方法概述
建 模 能 力 的 比 较
1.4 Verilog HDL目前的应用情况 和适用的设计
在美国,在高层逻辑电路设计领域Verilog HDL和 VHDL的应用比率是60%和40%,在其它地区各为 50%。Verilog HDL是专门为复杂数字逻辑电路和 系统的设计仿真而开发的,本身就非常适合复杂 数字逻辑电路和系统的仿真和综合。由于Verilog HDL在其门级描述的底层,也就是在晶体管开关的 描述方面比VHDL有强得多得功能,所以即使是 VHDL的设计环境,在底层实质上也是由Verilog HDL描述的器件库所支持的。
近年来,FPGA和ASIC的设计在规模和复杂度 方面不断取得进展,而对逻辑电路及系统的设 计的时间要求却越来越短。这些因素促使设计 人员采用高水准的设计工具,如:硬件描述语 言(Verilog HDL或VHDL)来进行设计。
1.5.2. Verilog HDL设计法与传统的电路 设计法与传统的电路 原理图输入法的比较
采用电路原理图输入法进行设计,具有设计 的周期长,需要专门的设计工具,需手工布线等 缺陷。 而采用Verilog HDL设计时具有以下优点: 1、设计者可以在非常抽象的层次上对线路进 行描述而不必选择特定的制造工艺。逻辑综合工 具可以将设计自动转换成任意一种制造工艺版图。 如果出现新的制造工艺,设计者不必对电路进行 重新设计,只要将RTL级描述输入综合工具,即可 生成针对新工艺的门级网表。(工艺无关性)。
硬核(Hard Core) 在某一种专用半导体集成电路 工艺的(ASIC)器件上实现的经验证是正确的 总门数在5000门以上的电路结构掩膜,称之为 “硬核”。 为了逻辑电路设计成果的积累,和更快更好地 设计更大规模的电路,发展软核的设计和推广 软核的重用技术是非常有必要的。新一代的数 字逻辑电路设计师必须掌握这方面的知识和技 术。
Verilog HDL 数字系统设计及实践 第3章 Verilog行为描述
Verilog HDL 数字系统设计及实践
第3章 Verilog行为描述
学习指南
•【知识目标】 •(1) 了解initial和always语句的概念; •(2) 了解块语句及过程赋值语句的概念和形式; •(3) 理解条件语句,多路分支语句和循环语句的功能特点; •(4) 理解各种时序控制的机制及形式。 •【技能目标】 •(1) 能够建立各种基本的行为模型。 •【重点难点】 •(1) 非阻塞赋值与阻塞赋值的区别; •(2) 各种时序控制机制的特点及应用。
并行块: 并行块中的语句是并行执行的,一旦仿真进入到并行。若使用延迟语句,则每条语句的延迟值是 都是相对于并行块开始执行的仿真时刻而言的,与前后语句的执行顺序无关。 块语句的其他特点: 块语句可以嵌套,顺序块与并行块可以混合使用 。 块语句可以被命名,称为命名块。在命名块中我们可以声明局部变量,但只 能在块内使用。
思考与练习
6. 上题的代码改写如下 initial begin a = 1’b0; b = 1’b0; c = 1’b1; b <= #10 1’b1; c <= #5 1’b0; d <= #15 {a,b,c}; end 请问每条语句执行的仿真时刻是多少?仿真结束后,各变量值是多少? 7. 请设计一个可选择的计算单元,输入a,b位宽为8,输出结果ret为9位,如下图
3.5 条件语句
条件语句可以根据某个判定条件来确定后面的语句是否执行。条件语句使用的关 键字为“if”和“else” if (条件表达式) 条件为真执行的语句; 或: if (条件表达式) 条件为真执行的语句; else 条件为假执行的语句;
Verilog HDL数字系统设计及实践
读书笔记
中规中矩的verilog书,该有的都有。 个人感觉前面章节都比较好理解,最后一章有点难,适合新手阅读。 新手看它就像活在梦里,初期代码风格似乎有变化,但是之后稳定了,也容易明白了。
目录分析
1.2模块和端口
1.1一个简单的例 子—— 4位全加器
的设计
1.3层次化设计思 想
1.4 Testbench的 概念
9.3 include 9.4 timescale
本章小结
9.5预编译处理实 例
思考与练习
0 1
10.1阻塞 语句与非阻 塞语句
0 2
10.2敏感 变量的不完 备性
0 3
10.3锁存 器的产生与 危害
0 4
10.4组合 逻辑反馈
0 6
10.6优先 级与并行编 码
0 5
10.5 for 循环
10.7多路控制分支 结构
Verilog HDL数字系统设计及实践
读书笔记模板
01 思维导图
03 读书笔记 05 作者介绍
目录
02 内容摘要 04 目录分析 06 精彩摘录
思维导图
关键字分析思维导图
设计
内容
逻辑
层次化
建模
小结
实例
数字
行为
共章 设计
形式
设计
语句
时间
描述
行为
时序
器
内容摘要
本书介绍硬件描述语言Verilog HDL及电路设计方法,共11章,主要内容包括:Verilog HDL层次化设计、 Verilog HDL基本语法、Verilog HDL行为描述、组合逻辑建模、行为级仿真模型建模、各层次Verilog HDL描 述形式与电路建模、任务和函数、编译预处理、Verilog HDL设计与综合中的陷阱、异步设计与同步设计的时序 分析。
veriloghdl答案
verilog-hdl答案第1章简介1.Verilog HDL是在哪一年首次被IEEE标准化的?Verilog HDL是在1995年首次被IEEE标准化的。
2.Verilog HDL支持哪三种基本描述方式Verilog HDL可采用三种不同方式或混合方式对设计建模。
这些方式包括:行为描述方式—使用过程化结构建模;数据流方式—使用连续赋值语句方式建模;结构化方式—使用门和模块实例语句描述建模3.可以使用Verilog HDL描述一个设计的时序吗?Verilog HDL可以清晰的建立时序模型,故可以使用Verilog HDL描述一个设计的时序。
4.语言中的什么特性能够用于描述参数化设计?在行为级描述中, Verilog HDL不仅能够在RT L级上进行设计描述,而且能够在体系结构级描述及其算法级行为上进行设计描述,而且能够使用门和模块实例化语句在结构级进行结构描述,这种特性可用于描述参数化设计。
5.能够使用Verilog HDL编写测试验证程序吗?能,可以编写testbench来对编写的程序进行验证。
6.Verilog HDL是由哪个公司最先开发的?Verilog HDL是由Gateway Design Automation公司最先开发的7.Verilog HDL中的两类主要数据类型是什么?线网数据类型和寄存器数据类型。
线网类型表示构件间的物理连线,而寄存器类型表示抽象的数据存储元件。
8.UDP代表什么?UDP代表用户定义原语9.写出两个开关级基本门的名称。
pmos nmos10.写出两个基本逻辑门的名称。
and or第2章 HDL指南1. 在数据流描述方式中使用什么语句描述一个设计?设计的数据流行为使用连续赋值语句进行描述2. 使用` t i m e s c a l e 编译器指令的目的是什么?举出一个实例。
使用编译指令将时间单位与物理时间相关联。
例如` timescale 1ns /100ps 此语句说明时延时间单位为1ns并且时间精度为100ps (时间精度是指所有的时延必须被限定在0.1ns内)3. 在过程赋值语句中可以定义哪两种时延?请举例详细说明。
Verilog HDL语言的描述语句
第4节Verilog HDL语言的描述语句Verilog HDL 描述语句2.4.1 结构描述形式通过实例进行描述的方法,将Verilog HDL预先定义的基本单元实例嵌入到代码中,监控实例的输入。
Verilog HDL中定义了26个有关门级的关键字,比较常用的有8个。
在实际工程中,简单的逻辑电路由逻辑门和开关组成,通过门元语可以直观地描述其结构。
基本的门类型关键字如下所述:•and•nand•nor•or•xor•xnor•buf•notVerilog HDL支持的基本逻辑部件是由该基本逻辑器件的原语提供的。
其调用格式为:门类型<实例名> (输出,输入1,输入2,……,输入N)例如,nand na01(na_out, a, b, c );表示一个名字为na01的与非门,输出为na_out,输入为a, b, c。
例2-5 一个简单的全加器例子:module ADD(A, B, Cin, Sum, Cout);input A, B, Cin;output Sum, Cout;// 声明变量wire S1, T1, T2, T3;xor X1 (S1, A, B),X2 (Sum, S1, Cin);and A1 (T3, A, B),A2 (T2, B, Cin),A3 (T1, A, Cin);or O1 (Cout, T1, T2, T3);endmodule在这一实例中,模块包含门的实例语句,也就是包含内置门xor、and和or的实例语句。
门实例由线网型变量S1、T1、T2和T3互连。
由于未指定顺序,门实例语句可以以任何顺序出现。
门级描述本质上也是一种结构网表。
在实际中的使用方式为:先使用门逻辑构成常用的触发器、选择器、加法器等模块,再利用已经设计的模块构成更高一层的模块,依次重复几次,便可以构成一些结构复杂的电路。
其缺点是:不易管理,难度较大且需要一定的资源积累。
2.4.2 数据流描述形式数据流型描述一般都采用assign连续赋值语句来实现,主要用于实现组合功能。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
思考与练习
8. 有如下一段代码 initial begin b = 1’b0; #0 b = 1’b1; c = #1 b; end 请问c的最终值是多少? 9. 有如下一段代码 initial while(enable) #20 clk = ~clk; 请将上面的代码用always和wait语句改写,实现同样的行为。 10. 有一个模块fadder_4,其功能为4位全加器,输入端口为A[3:0](加数1),B[3:0] (加数2),输出端口为S[3:0](和),C(进位)。请写一个testbench测试此全加器, 要求测试所有加数的组合。 11. 请设计一个门控时钟信号,周期为20个时间单位,占空比30%,门控信号为enable, 当门控信号为高,输出时钟信号,当门控信号为低,无时钟输出为低。要求时钟切换时 无毛刺。
3.3 顺序块和并行块
块语句的作用是可以将两条或更多的过程语句组合在一起,变成像一条过程语句一样 的语法结构。块语句可以分为两种:一种是begin...end语句,块里面的语句顺序执行, 称为顺序块;另一种是fork…join语句,块里面的语句并行执行,称为并行块。 顺序块: 顺序块中的各条语句是按顺序执行的,前一条语句执行完后才能执行后一条 语 句,所以每条语句的延迟值是对前一条语句的仿真时间而言的。
3.9 时序控制
3.9.2事件控制 基于事件的时序控制是指通过事件的发生来触发语句的执行。在Verilog语言中, 一个事件通常是指一个变量、线网信号或表达式的值发生变化。所以语句的执行在指 定变量的值发生变化的时刻开始,从而提供了更灵活和复杂的时序控制方法。基于事 件的控制大致可以分为:边沿敏感事件控制和电平敏感事件控制。 (1). 边沿敏感事件控制 边沿敏感事件控制用符号@来说明,其格式为: @ 事件 语句; 或: @ (事件1 or 事件2 ... or 事件n) 语句; 或: @ (事件1, 事件2, ..., 事件n) 语句; 例如: @clock a = ~a; @(posedge clk) data = d;
并行块: 并行块中的语句是并行执行的,一旦仿真进入到并行块,则块里面的所有语句都同 从并行 的仿真时刻同时开始执行。若使用延迟语句,则每条语句的延迟值是 都是相对于并行块开始执行的仿真时刻而言的,与前后语句的执行顺序无关。 块语句的其他特点: 块语句可以嵌套,顺序块与并行块可以混合使用 。 块语句可以被命名,称为命名块。在命名块中我们可以声明局部变量,但只 能在块内使用。
3.9 时序控制
时序控制是Verilog语言中比较重要的语句。在Verilog设计中通过各种时序控制语句可 以指定过程语句执行的时刻,从而实现特定的与时间有关的电路时序功能。Verilog提供 了两种类型的时序控制方法:基于延迟的时序控制和基于事件的时序控制。 3.9.1延迟控制 基于延迟的时序控制用在表达式中,用于指定语句开始执行到执行完成之间的时 间间隔。其形式为 # [延迟值],其中延迟值可以是常数,变量或表达式。基于延迟的 时间控制通常可分为两种形式:常规延迟和内嵌延迟。 (1).常规延迟 常规延迟控制语句将指定延迟的语句放在赋值语句的最左边,用来给赋值语句指 定一个延迟值,其语法格式如下: #[延迟值] 语句; (2).内嵌延迟 延迟控制也可以放到赋值语句中,写在赋值语句等号的右边。
3.4 过程赋值语句
过程赋值语句指在 initial 语句或 always 语句中对变量进行赋值的语句,它们 只能对寄存器、整数等变量进行赋值。这些变量数据在被赋值后,值保持不 变,直到下一个过程赋值语句对它们赋新的值。 阻塞赋值语句:阻塞赋值语句用“=”作为赋值符。阻塞语句按顺序执行, 在下一条语句执行之前,上一条赋值语句必须执行完毕。 非阻塞赋值语句:非阻塞语句用“<=”作为赋值符。非阻塞赋值语句不会阻 塞同一个块语句中的其他语句的执行。注意非阻塞赋值语句的赋值符与关系 操作符的小于等于符号是一样的,它在不同的语法环境下被解释成不同的语 法含义。
3.1 Verilog的基本描述形式
对于模块内具体电路功能逻辑的描述,通常有下面3种方式: (1).数据流描述方式:使用连续赋值语句对数据流行为进行描; (2).行为描述方式:使用结构化过程语句对时序行为进行描述。其中结构化过程 语句包括 两种语句:initial语句和always语句。 (3).层次化描述方式:使用原语或模块的实例化对电路结构进行描述(其中原语 包括内建门级原语,开关级原语,用户自定义原语
Verilog HDL 数字系统设计及实践
第3章 Verilog行为描述
学习指南
• 【知识目标】 • (1) 了解initial和always语句的概念; • (2) 了解块语句及过程赋值语句的概念和形式; • (3) 理解条件语句,多路分支语句和循环语句的功能特点; • (4) 理解各种时序控制的机制及形式。 • 【技能目标】 • (1) 能够建立各种基本的行为模型。 • 【重点难点】 • (1) 非阻塞赋值与阻塞赋值的区别; • (2) 各种时序控制机制的特点及应用。
注意:if与else的配对关系,else总是与它之前的最近一个没有else的if配对。尤其 在if嵌套的语句中,配对关系易混淆,需注意区分以避免逻辑错误。
3.6 多路分支语句
case语句的关键字为“case”,“default”和“endcase”。其格式如下: case ( 表达式 ) 分支表达式1:语句1; 分支表达式2:语句2; …… default:默认语句; endcase
3.5 条件语句
条件语句可以根据某个判定条件来确定后面的语句是否执行。条件语句使用的关 键字为“if”和“else” if (条件表达式) 条件为真执行的语句; 或: if (条件表达式) 条件为真执行的语句; else 条件为假执行的语句;
或: if (条件表达式1) 条件为真执行的语句1; else if (条件表达式2) 条件为真执行的语句2; else if (条件表达式3) 条件为真执行的语句3; …… else 条件为假执行的语句1;
3.8 循环语句
3.8.4 forever循环 forever语句的关键字为forever,其格式为: forever 语句; forever循环是永久循环,不需要任何条件表达式,也不做任何计算与判断。 Forever 无条件的做无限次循环,直到仿真结束。同样循环语句如果为一组,需要 begin…end或fork…join组合为块语句。
3.8 循环语句
3.8.2 for循环 for循环的关键字为for,格式为: for ( 初始条件表达式; 终止条件表达式; 控制变量表达式 ) 语句; for循环的运行方式与C语言中的for语句相同,即首先执行初始表达式,然后每 次开始新的循环时计算终止条件表达式,如果终止条件表达式的值为真,则执行for 循环中的语句一次。执行完一次循环后,无条件执行控制变量表达式,然后重新开 始下一次循环。如果终止条件表达式的值为假,则结束循环,跳出for语句。 3.8.3 repeat循环 repeat循环的关键字为repeat,其格式为: repeat ( 循环次数表达式 ) 语句; repeat循环最大的特点是执行固定次数的循环,它不能根据某个条件表达式来决定 循环执行与否。其中循环次数必须是一个常量,变量或者表达式。同样,如果一次循 环需要执行多条语句,则需要用begin..end或fork…join组合为块语句。
思考与练习
6. 上题的代码改写如下 initial begin a = 1’b0; b = 1’b0; c = 1’b1; b <= #10 1’b1; c <= #5 1’b0; d <= #15 {a,b,c}; end 请问每条语句执行的仿真时刻是多少?仿真结束后,各变量值是多少? 7. 请设计一个可选择的计算单元,输入a,b位宽为8,输出结果ret为9位,如下图
3.2 结构化过程语句
结构化过程语句包含两种:initial语句和always语句,它们也是行为描述方式的基本语句。 所有行为描述的其他语句(如过程赋值语句)必须包含在这两种语句当中。 3.2.1initial语句 一条initial语句从仿真的0时刻开始执行,但是只执行一次。如果initial语句中包含了多 条行为语句,那么需要用begin和end将其组合成块语句如果只包含了单条行为语句则不 必使用begin和end。
(1)if…else语句带有优先级,而case语句则没有,是并行的关系。 (2)在嵌套的 if…else语句中,每一个条件判断是一种层层递进的形式,最前面的if 判断语句具有最高的优先级。在 case语句中,各个条件判断则是一种并列形式,与 条件表达式的顺序无关。
3.8 循环语句
Verilog语言中有四种类型的循环语句:while,for,repeat和forever。它们都 只能在initial或always语句模块中使用。 3.8.1while循环 while循环的关键字为while,其格式为: while ( 条件表达式 ) 语句; 当条件表达式为真,则循环执行里面的语句,如果条件表达式为假,则中止循 环并跳出while。
latch_rst D EN CLR Q o练习
1. 设计一个时钟信号,周期为20个时间单位,占空比30%。 2. 请将一个位宽为8,地址范围为64的寄存器数组进行初始化,所有位均设置为1。 3. 设计一个带同步复位的D触发器。(清零端低电平有效,在时钟上升沿执行清零操 作) 4. 请描述如下的一个电路模型:在每一个时钟上升沿检查输入信号pwd(位宽为8), 如果其值为55H或者AAH,输出信号flag为1,并显示pwd的值,否则flag为0,并显示 “error!”。 5. 看下面的一段代码 initial begin a = 1’b0; b = 1’b0; c = 1’b1; #10 b = 1’b1; #5 c = 1’b0; #15 d = {a,b,c}; end 请问每条语句执行的仿真时刻是多少?仿真结束后,各变量值是多少?