硬件描述语言及其程序设计方法
VHDL硬件描述语言与数字逻辑电路设计 (5)[88页]
第5章 VHDL构造体的描述方式
5.1 构造体的行为描述方式 5.2 构造体的寄存器传输(RTL)描述方式 5.3 构造体的结构描述方式 习题与思考题
第5章 VHDL构造体的描述方式
5.1 构造体的行为描述方式
什么样的描述属于行为描述方式,这一点目前还没有确 切的定义,所以在不同的书刊中,对相同或相似的某些用 VHDL描述的逻辑电路的程序有不同的说明。有的说明为行 为描述方式,有的说明为寄存器传输描述方式。但是,有一 点是明确的,行为描述方式是对系统数学模型的描述,其抽 象程度比寄存器传输描述方式和结构描述方式更高。
第5章 VHDL构造体的描述方式
5.1.2 延时语句 在VHDL中存在两种延时类型:惯性延时和传输延时。
这两种延时常用于VHDL的行为描述方式。 1.惯性延时 在VHDL中,惯性延时是缺省的,即在语句中如果不作
特别说明,产生的延时一定是惯性延时,这是因为大多数器 件在行为仿真时都会呈现这种惯性延时。
第5章 VHDL构造体的描述方式
第5章 VHDL构造体的描述方式
在例5-2中用了两个语句:第一个语句是选择语句,第 二个语句是代入语句。这两个语句是条件代入类型语句。也 就是说,只有WHEN后面所指定的条件得到满足时,指定的 代入值才被代入信号量sel或输出量q。
当第一个语句执行时,将使用选择信号。根据选择信号 sel的当前值,后跟的5种状态下的值i0~i3、'X' 中的一个值 将通过输出端口q输出。在正常情况下,q端将选择i0~i3之 一输出,在非正常情况下将输出 'X' 值。
第5章 VHDL构造体的描述方式
几乎所有器件都存在惯性延时,因此,硬件电路的设计 人员为了逼真地仿真硬件电路的实际工作情况,在代入语句 中总要加上惯性延时时间的说明。例如:
EDA课件第三章
tmp2:=d1 AND (NOT sel); tmp3:=tmp1 OR tmp2; tmp<=tmp3;
q<=tmp AFTER m; END PROCESS cale;
END ARCHITECTURE connect;
(2) 端口方向
端口方向用来定义外部引脚的信号方向是输入还 是输出。
凡是用“IN”进行方向说明的端口,其信号自端口 输入到构造体,而构造体内部的信号不能从该端口输 出。相反,凡是用“OUT”进行方向说明的端口,其信 号将从构造体内经端口输出,而不能通过该端口向构 造体输入信号。
实体说明
一个模块中仅有一 个设计实体。
实体 提供设计模块的接口信息,是VHDL设计电 路的最基本部分。
实体说明具有如下的结构:
ENTITY 实体名 IS
实体说明以“ENTITTY 实体名
[类属参数说明];
IS”开始至“END ENTITTY实体 名”结束。这里大写字母表示
实体说明的框架。实际上,对
此例中的外部引脚
ARCHITECTURE connect OF mux IS SIGNAL tmp:BIT; BEGIN
cale:PROCESS(d0,d1,sel) IS VARIABLE tmp1,tmp2,tmp3:BIT;
BEGIN tmp1:=d0 AND sel;
为d0,d1,sel,q 。
库(Library)是经编译后的数据的集合,它存放包集合 定义、实体定义、构造体定义和配置定义。
设计中的子程序和 公用数据类型的集合。
程序包
IEEE标准的标准程序包 设计者自身设计的程序包
包和库具有这样的关系:多个过程和函数汇集在一起构成包 集合,而几个包汇集在一起就形成一个库。
硬件描述语言
硬件描述语言硬件描述语言(HardwareDescriptionLanguage,HDL),是一种特殊的编程语言,旨在帮助设计人员(称作HDL程序员)创建电子系统的软硬件。
它支持现在最先进的电子系统,并能够提供开发方案,以更快地实现目标,更有效地使用更少的资源,并且更稳定地完成任务。
HDL是一种高级程序设计语言,由若干种编程语言构成,其中包括Verilog,VHDL, SystemVerilog等。
HDL语言描述技术主要用于描述单片机或模拟集成电路(IC)中的复杂电路结构和功能。
它以硬件参数、原语和结构描述为基础,能够描述逻辑系统的底层电路,比如门逻辑、触发器、多路选择器、比较器等。
HDL具有许多优点,能够极大地降低电路设计的困难程度,同时简化设计的复杂性和过程,可以提高设计效率和提升最终产品的性能。
HDL提供方便的调试和测试功能,可以支持电路设计过程管理,减少产品设计和开发的工作量。
此外,HDL能够提供标准、可重用的描述,以及可读性好的语法,可以显著简化设计过程。
HDL的另一个重要优点是,它可以帮助HDL程序员创建更复杂、更现代化的电路设计,而不需要编译器和其它复杂的程序设计开发工具。
HDL可以提供电路设计过程中所需的所有功能,包括定义电路功能,输入输出管理,系统级构建,网络结构,状态机控制,信号处理,数据传输等。
它还利用可视化技术以及带有标准和完善的接口,能够更快地识别和定位问题,大大降低了调试产品的时间。
HDL的另一个优点在于,它具有许多可扩展性,无需为每个项目开发新的硬件。
HDL能够有效地管理工厂现有的系统设计,例如将新的硬件模块添加到已有的电路框架中,并且能够有效地利用已有的硬件,尽可能减少更改硬件布局的时间。
当今,HDL已经成为电子行业中最专业化的编程语言,并被广泛应用于微处理器、嵌入式系统、数字信号处理(DSP)、模拟信号处理(ASP)、网络交换、存储器系统,以及其它领域。
HDL在加速设计过程、改善产品质量、减少产品成本方面十分有用,是现今许多企业进行电子产品设计的重要工具。
数字逻辑与部件设计-硬件描述语言+HDL
• 综合 Synthesis
– High Level Synthesis
– RTL Synthesis
– Logic Synthesis
• 布图 Layout
网表netlist
– 布局 (Placement)
– 布线 (Routing)
• 版图参数提取和验证
如导线电阻,导线间寄生电容
• 测试和诊断
4
begin
A1 = 1'b0; B1 = 1'b0; C1 = 1'b0; //1位二进制0
#100 A1 = 1'b1; B1 = 1'b1; C1 = 1'b1;
end
initial #200 $finish; //200ns结束
endmodule
不知其值是多少
16
Vivado2015中模拟结果
|
或
||
逻辑或
===
全等
^
异或
!==
不全等
^~
同或
AND优先级比OR高
• 缩位运算符:对单个操作数进行运算,最后返回一位数。
运算过程:首先将操作数的第一位和第二位进行与、或、非运算;
然后再将运算结果和第三位进行与、或、非运算;以此类推直至
最后一位。例子见下页...
• 拼接运算符:{s1, s2, …, sn}
2
g6
endmodule
g5
3
13
练习2. 画出下面的电路图
module Circuit_2 (A, B, C, D, F);
input A, B, C, D;
output F;
wire w, x, y, z, a, d;
第2章+硬件描述语言
2.1 2.2
VHDL硬件描述语言
Verilog硬件描述语言
电子设计自动化技术(EDA:Electronic Design Automatic) 是指以计算机为工作平台,融合了应用电子技术、 计算机技术、智能化技术的最新成果而开发出的电 子CAD通用软件包。 它根据硬件描述语言HDL(Hardware Description Language)描述的设计文件,自动完成逻辑、化简、 分割、综合、优化、布局布线及仿真,直至完成对 于特定目标芯片的适配编译、逻辑映 射和编程下载 等工作。
2.2 Verilog硬件描述语言
Verilog HDL程序由模块构成,模块的内容都 是嵌在module和endmodule两个关键字之间,每个 模块实现特定的功能。模块之间可以进行层次的 嵌套。
2.2.1 Verilog HDL 程序基本结构
module <模块名> (<输入、输出端口列表>);
4)其他运算符
类别
赋值运算符 关联运算符 并置运算符 & <= := =>
运算符
功能 信号赋值
变量赋值
数据类型
例化元件时用于 形参到实参的映 射 连接 bit、std_logic
2.1.3 并行语句
VHDL内部的语句分为两大类:并行语句和顺序语
句。 常用的并行语句有:
信号赋值语句 进程语句(process)
块语句(block)
元件例化语句(component) 生成语句(generate) 并行过程调用语句。
2.1.4 顺序语句 顺序语句只能出现在进程(Process) 、函数(Function)
和过程(Procedure)中。顺序语句包括:信号赋值语 句、变量赋值语句、流程控制语句、等待语句、子 程序调用语句、返回语句、空操作语句等。
VHDL硬件描述语言与数字逻辑电路设计 第1章
图1-2 六进制约翰逊计数器原理图
12
与六进制计数器模块设计一样,系统的其它模块也按此 方法进行设计。在所有硬件模块设计完成以后,再将各模块 连接起来,进行调试。如有问题,则进行局部修改,直至整 个系统调试完毕为止。
由上述设计过程可以看到,系统硬件的设计是从选择具 体元器件开始的,并用这些元器件进行逻辑电路设计,完成 系统各独立功能模块的设计,然后将各功能模块连接起来, 完成整个系统的硬件设计。上述过程从最底层开始设计,直 至最高层设计完毕,故将这种设计方法称为自下至上的设计 方法。
26
第二层次是RTL方式描述。这一层次称为寄存器传输描 述(又称数据流描述)。如前所述,用行为方式描述的系统结 构的程序其抽象程度高,是很难直接映射到具体的逻辑元件 结构用硬件来实现的。要想得到硬件的具体实现,必须将行 为方式描述的VHDL语言程序改写为RTL方式描述的VHDL 语言程序。也就是说,系统采用RTL方式描述,才能导出系 统的逻辑表达式,才能进行逻辑综合。当然,这里所说的可 以进行逻辑综合是有条件的,它是针对某一特定的逻辑综合 工具而言的。
16
传统的硬件电路设计方法已经沿用了几十年,是目前广 大电子工程师所熟悉和掌握的一种方法。但是,随着计算机 技术、大规模集成电路技术的发展,这种传统的设计方法已 大大落后于当今技术的发展。一种崭新的、采用硬件描述语 言的硬件电路设计方法已经兴起,它的出现给硬件电路设计 带来了一次重大的变革。
17
1.2 利用硬件描述语言的硬件电路 设计方法
5
要设计一个六进制计数器,其方案是多种多样的,但是 摆在设计者面前的一个首要问题是如何选择现有的逻辑元器 件构成六进制计数器。设计六进制计数器首先从选择逻辑元 器件开始。
第一步,选择逻辑元器件。由数字电路的基本知识可知, 可以用与非门、或非门、D触发器、JK触发器等基本逻辑元 器件来构成一个计数器。设计者根据电路尽可能简单、价格 合理、购买和使用方便等原则及各自的习惯来选择构成六进 制计数器的元器件。本例中选择JK触发器和D触发器作为构 成六进制计数器的主要元器件。
硬件描述语言verilog_HDL基础
12
1.4 Verilog 目前的应用情况和适用的设计
Verilog 较为适合系统级(System)、算法 级(Alogrithem)、寄存器传输级(RTL)、逻辑 (Logic)、门级(Gate)和电路开关级(Switch)的
设计,而对于特大型(千万门级以上)的系 统级(System)设计,则VHDL更为合适。
2020/2/28
13
1.5 采用 Verilog HDL 设计复杂数字电路的优点
1.5.1 传统设计方法——电路原理图输入法
采用电路原理图输入法进行设计,周期长、需 要专门的设计工具、需手工布线等。这种低水平的 设计方法大大延长了设计周期。
2020/2/28
14
1.5.2 Verilog HDL 设计法与传统的电路 原理图输入法的比较
2020/2/28
3
什么是硬件描述语言
具有特殊结构能够对硬件逻辑电路的功能进行描述的一种高级 编程语言
这种特殊结构能够:
描述电路的连接 描述电路的功能 在不同抽象级上描述电路 描述电路的时序 表达具有并行性
HDL主要有两种:Verilog和VHDL
Verilog起源于C语言,因此非常类似于C语言,容易掌握 VHDL格式严谨 VHDL出现较晚,但标准化早。IEEE 1706-1985标准。
2020/2/28
24
概述
Verilog HDL行为描述语言具有以下功能:
• 可描述顺序执行或并行执行的程序结构。 • 用延迟表达式或事件表达式来明确地控制过程的启动时间。 • 通过命名的事件来触发其它过程里的激活行为或停止行为。 • 提供了条件如if-else、case、循环程序结构。 • 提供了可带参数且非零延续时间的任务(task)程序结构。 • 提供了可定义新的操作符的函数结构(function)。 • 提供了用于建立表达式的算术运算符、逻辑运算符、位运算 符。 • Verilog HDL语言作为一种结构化的语言也非常适合于门级 和开关级的模型设计。
vhdl程序设计教学大纲
《VHDL硬件描述语言》教学大纲一、课程基本信息课程名称:VHDL硬件描述语言课程编码:31082008课程类别:学科基础选修课程适用专业:计算机科学与技术开课学期:第3学年第1学期课程学时:32课程学分:2先修课程:数字逻辑电路并修课程:算法分析课程简介:vhdl是计算机科学与技术专业选修的基础课程,主要讲述vhdl硬件描述语言的基础知识,以及用vhdl硬件描述语言设计的基本理论和方法。
数字逻辑电路课程包括vhdl程序结构和描述、vhdl 顺序语句,并行语句,数字逻辑单元的设计等内容。
二、课程教育目标通过vhdl 语言课程的学习,使学生掌握vhdl硬件描述语言的基本原理和设计方法,运用vhdl语言设计基本的数字电路设计,为以后学习计算机组成原理、计算机配置与维护等后续课程以及从事数字电子技术领域的工作打下扎实的基础。
三、课程教学内容、要求及学时安排第一章 EDA技术概述和 vhdl语言【教学内容】1. EDA技术概述2. vhdl 语言概述【教学要求】1.了解EDA技术和vhdl语言。
【教学方法】理论联系实际,课堂讲授,课后作业等。
【学时】1第二章 vhdl语言基础【教学内容】1. vhdl程序结构2. vhdl 语言描述3. vhdl语言的数据类型4. vhdl 语言的顺序描述语句5. vhdl 语言的并发描述语句【教学要求】1.掌握vhdl语言的顺序描述语句,并发描述语句。
2.熟悉vhdl语言的结构。
3.了解vhdl语言的数据类型。
【教学方法】理论联系实际,课堂讲授,课后作业等。
【学时】9第三章数字逻辑单元设计【教学内容】1.组合逻辑电路设计2.数据运算单元设计3. 时序逻辑电路设计【教学要求】1.掌握组合逻辑电路设计和时序逻辑电路设计。
2.熟悉数据运算单元设计。
3.了解总线缓冲单元设计。
【教学方法】理论联系实际,课堂讲授,课后作业等。
【学时】10四、考核及成绩评定(一)命题原则与思想综合考核所学知识、各章节的知识点、要求掌握的基本知识和基本原理,试题难易适中,学习成绩具有一定的区分度。
VHDL硬件描述语言与数字逻辑电路设计第三版课程设计
VHDL硬件描述语言与数字逻辑电路设计第三版课程设计本次课程设计旨在帮助大家深入理解VHDL硬件描述语言和数字逻辑电路设计的相关知识,提高大家的实践能力和设计能力。
本文将对课程设计的要求和实现方法进行详细说明。
课程设计要求本次课程设计要求大家完成一个基于VHDL的数字逻辑电路设计,包括以下要求:1.手动编写VHDL程序,对指定的数字电路进行仿真分析,并输出相应的波形图。
2.设计一个数字电路,要求该电路可完成特定的逻辑功能,例如加法器、多路选择器等。
3.基于现实的场景需求,完成一个实际的数字电路设计。
例如,实现一个音乐播放器控制器、机器人控制器等。
设计步骤步骤一:了解VHDL语言和数字逻辑电路设计原理在进行数字电路设计之前,需要先理解VHDL语言和数字逻辑电路设计原理。
VHDL语言是一种硬件描述语言,主要用于描述数字逻辑电路。
数字逻辑电路由基本的逻辑单元组成,包括与门、或门、非门等,通过组合这些逻辑单元可以实现更复杂的逻辑电路设计。
步骤二:选择仿真工具选择一款仿真工具进行仿真分析。
常见的仿真工具有ModelSim、Xilinx ISE 等。
步骤三:编写VHDL程序编写VHDL程序,对指定的数字电路进行仿真分析。
根据实际需要,可以选择不同的VHDL语言结构进行编写。
步骤四:仿真分析在仿真工具中进行仿真分析,根据VHDL程序模拟出相应的波形图。
步骤五:设计数字电路基于数字逻辑电路设计原理,设计出特定的数字电路。
需要首先确定电路所需要的逻辑功能,然后根据这个功能设计出合适的电路。
步骤六:实现实际场景需求参考现实的场景需求,设计出一个实际的数字电路,并进行调试测试。
VHDL程序编写规范在编写VHDL程序时,需要遵循一定的编写规范,以保证程序的可读性和可维护性。
1.命名规范:变量和信号的命名应具有较好的描述性,易于理解和记忆。
2.缩进规范:代码缩进应该统一,便于代码的阅读和理解。
3.注释规范:代码中应加入必要的注释,解释各个模块的功能和作用。
硬件描述语言(VHDL)
(1)体内配置指定
(2)体外配置说明
由于体外配置语句是一个独立的编译单位, 故需给它指定一个单位名—配置名。实体 名和结构体名为需对例元做配置的实体及 相应的结构体。
(3)直接例化
二. VHDL语言的数据对象,数据类型
TYPE week IS(sum,mon,tue,wed,thu,fri,sat);
2.整数,实数(Integer,Real)类型 格式:TYPE 数据类型名 IS 数据类型定义约束范围
TYPE twos IS INTEGER RANGE –32768 TO 32767; TYPE voltage IS REAL RANGE 0.0 TO 10.0;
结构体的子结构描述:
BLOCK,PROCESS,SUBPROGRAM三种语句结构
1. BLOCK语句结构描述
格式: 块结构名: BLOCK BEGIN ….
END BLOCK 块结构名;
在对程序进行仿真时,BLOCK语句中所描述的各个语 句是可以并发执行的,它与书写顺序无关。 卫式BLOCK语句的格式::BLOCK [卫式布尔表达式]; 当卫式布尔表达式为真时,BLOCK语句执行。
为了能重复使用这些函数和过程,这些程 序通常组织在包集合库中。 (1)多个过程和函数汇集在一起就构成一个 包集合(Package)。 (2)n个包集合汇集在一起就形成一个库 (Library)。
(三) 包集合,库及配置
1.库(Library):它是一个经过编译后的数据的集合, 存放包集合EE库,STD库,ASIC矢量库, WORK库,用户定义库。
asic芯片编程语言
ASIC芯片编程语言是一种专门用于编写ASIC芯片的程序的语言,它与普通的编程语言不同,因为它需要考虑到ASIC芯片的硬件特性和设计规则。
常见的ASIC芯片编程语言包括VHDL、Verilog、SystemVerilog等。
这些语言都有自己的特点和适用范围,需要根据具体的应用场景和需求来选择。
VHDL是一种硬件描述语言,它主要用于描述数字系统的结构和行为,适用于ASIC和FPGA 设计。
VHDL语法严谨、规范,易于阅读、编写和调试,适用于描述复杂数字系统的行为。
它适合于描述算法和逻辑电路,易于移植到不同的硬件平台上。
Verilog是一种面向结构的硬件描述语言,它主要用于描述数字系统的结构和功能,适用于ASIC和FPGA设计。
Verilog语法简洁、易学易用,适合于描述电路模块和系统级设计。
它支持并行执行和组合逻辑,适用于描述大规模数字系统的行为。
SystemVerilog是一种基于Verilog的验证和测试语言,它提供了更多的验证和测试功能,适用于ASIC和FPGA设计。
SystemVerilog支持异常处理、并发结构和并发验证方法,适用于描述复杂数字系统的行为和功能。
它还提供了许多用于验证的测试工具和测试框架,提高了设计的可靠性和可维护性。
除了以上三种语言外,还有一些其他的ASIC芯片编程语言,如C、C++等。
这些语言也可以用于ASIC芯片的设计,但它们需要考虑到硬件的特性和性能,需要进行一些特殊的优化和调整。
总之,ASIC芯片编程语言的选择需要考虑具体的应用场景和需求,不同的语言有不同的特点和适用范围。
在选择语言时,需要根据具体情况进行评估和选择,以获得最佳的设计效果和性能。
微机原理与接口技术第三章
实体说明及其外部接口信号关系
3.2.1 实体说明
1. 实体名
实体具体取名由设计者自定,但由于实体名实际
上表达的是该设计电路的器件名,所以最好根据相 应电路的功能来取定。例:counter16
实体名的命名要满足VHDL语言定义标识符的规则。
①第一个字符必须是字母; ②字母不区分大小写;③下划线
不能连用;④最后一个字符不能是下划线。
1 LIBRARY IEEE; 库和包说明部分 2 USE IEEE.STD_LOGIC_1164.ALL; 3 USE IEEE.STD_LOGIC_UNSIGNED.ALL; 4 5 6 7 8 9 ENTITY counter16 is GENERIC(n: INTEGER:=4); 实体说明部分 PORT(clk: IN STD_LOGIC; --时钟输入端 co:OUT STD_LOGIC; --进位输出端 q :OUT STD_LOGIC_VECTOR(n-1 DOWNTO 0)); END counter16;
3.2.1 实体说明
3. 端口(PORT)说明语句 端口说明语句指明实体的输入/输出信号及其模式。
端口说明语句的语法结构为:
PORT(端口名:端口模式 数据类型; … 端口名:端口模式 数据类型);
1) 端口名 端口名对应于元件符号的每个外部引脚的名称,一般由英 文字母组成。名字的定义有一定的惯例,如clk表示时钟,d开 头的端口名表示数据,a开头的端口名表示地址等。
STD_LOGIC_VECTOR等。建议:端口数据类型
只使用BIT、BIT_VECTOR、STD_LOGIC、 STD_LOGIC_VECTOR等具有电路特性的类型, 而不使用BOOLEAN、INTEGER 等数学意义明显 的类型。
VHDL语言实用教程
hwadee
2014-7-2
22
VHDL语言程序的基本构成示例
库、包集合说明
实体说明
构造体
hwadee
2014-7-2
23
库与包集合
用于存放预先编译好的程序包(PACKAGE)和数据集 合体,以便不同的VHDL设计使用(注:包集合存在于 库中) 库的说明总是放在设计单元的最前面,如: LIBRARY ieee; 前面LIBRARY 为关键字,后面ieee为库名称
hwadee ( 3)波形输入方式 2014-7-2 12
设计处理
逻辑优化
把逻辑描述转变为最适合在器件中实现的形式, 优化使设计所占用的资源最少。
逻辑综合
根据设计描述,对给定的硬件结构组件,最终获 得门级电路甚至更底层的电路描述文件,即将多 个模块化设计文件合并为一个网表文件。
适配
确定优化后的逻辑能否与器件中的宏单元和I/O单 元适配。
2014-7-2
10
PLD设计准备
在设计之前,首先要进行方案论证和器件选择等设计 准备工作。 设计者首先要根据任务要求,判断系统的可行性。 系统的可行性要受到逻辑要求合理性、成本、开发条 件、器件供应等方面的约束。
若系统可行,则根据系统所完成的功能及复杂程 度,对器件本身的ห้องสมุดไป่ตู้源和成本、工作速度及连线的可 布性等方面进行权衡,选择合适的设计方案和合适的 器件类型。
Altera公司:Maxplus Ⅱ、 QuartusⅡ Xilinx公司:Foundation、 ISE Lattice公司:Synario System、ispEXPERT System
hwadee
2014-7-2
Verilog 硬件描述语言参考手册-北航夏宇闻经典教程
VectorReg[Bit] = Expression; VectorReg[MSB:LSB] = Expression; Memory[Address] = Expression; assign Reg = Expression deassign Reg;
TaskEnable(...);
3
disable TaskOrBlock; EventName;
if (Condition) ...
else if (Condition)
...
else ...
case (Selection) Choice1 : ... Choice2, Choice3 : ... default : ... endcase
d for (I=0; I<MAX; I=I+1) e ... r repeat (8)
R ----------------------------------------------------------------------------Un 典型的 Verilog 模块的结构:
module M (P1, P2, P3, P4); input P1, P2; output [7:0] P3; inout P4; reg [7:0] R1, M1[1:1024]; wire W1, W2, W3, W4; parameter C1 = “This is a string”; initial begin : 块名 // 声明语句
4
Ÿ 如上面的许多例子所示,用一层层缩进的格式来写。 Ÿ 用户定义变量名的大小写应自始至终一致(例如,变量名第一个字母大写)。 Ÿ 用户定义变量名应该是有意义的,而且含有一定的有关信息。而局部名(例如循环变量)
什么是硬件描述语言
什么是硬件描述语言什么是硬件描述语言,你知道吗?今天就让店铺来教下大家吧,快来看看吧,希望能让大家有所收获!什么是硬件描述语言硬件描述语言HDL是一种用形式化方法描述数字电路和系统的语言。
利用这种语言,数字电路系统的设计可以从上层到下层(从抽象到具体)逐层描述自己的设计思想,用一系列分层次的模块来表示极其复杂的数字系统。
然后,利用电子设计自动化(EDA)工具,逐层进行仿真验证,再把其中需要变为实际电路的模块组合,经过自动综合工具转换到门级电路网表。
接下去,再用专用集成电路ASIC或现场可编程门阵列FPGA自动布局布线工具,把网表转换为要实现的具体电路布线结构。
硬件描述语言的概述随着EDA技术的发展,使用硬件语言设计PLD/FPGA成为一种趋势。
目前最主要的硬件描述语言是VHDL和Verilog HDL。
VHDL发展的较早,语法严格,而Verilog HDL是在C语言的基础上发展起来的一种硬件描述语言,语法较自由。
VHDL和Verilog HDL两者相比,VHDL的书写规则比Verilog烦琐一些,但verilog自由的语法也容易让少数初学者出错。
国外电子专业很多会在本科阶段教授VHDL,在研究生阶段教授verilog。
从国内来看,VHDL的参考书很多,便于查找资料,而Verilog HDL的参考书相对较少,这给学习Verilog HDL带来一些困难。
从EDA技术的发展上看,已出现用于CPLD/FPGA设计的硬件C语言编译软件,虽然还不成熟,应用极少,但它有可能会成为继VHDL和Verilog之后,设计大规模CPLD/FPGA的又一种手段。
硬件描述语言的结构硬件描述语言的优点(1)与其他的硬件描述语言相比,VHDL具有更强的行为描述能力,从而决定了他成为系统设计领域最佳的硬件描述语言。
强大的行为描述能力是避开具体的器件结构,从逻辑行为上描述和设计大规模电子系统的重要保证。
(2)VHDL丰富的仿真语句和库函数,使得在任何大系统的设计早期就能查验设计系统的功能可行性,随时可对设计进行仿真模拟。
高级程序设计语言和硬件描述语言VHDL的数据类型比较
1 引言 1.1 硬件描述语言 HDL( Har dwar e Descr iption Language)
硬件描述语言是一种用形式化方法描述数字电路和系统的 语言。利用这种语言, 数字电路系统的设计可以从上层到下层 ( 从抽象到具体) 逐层描述自己的设计思想, 用一系列分层次的 模块来表示极其复杂的数字系统。
VHDL 允许的数据类型包括标量数值类型、数组 类 型 、记 录 类型、枚举类型和文件类型[1]。在讨论各种 VHDL 数据类型前先 简单介绍一下 VHDL 对象类型的概念。
VHDL 对 象 包 括 信 号 ( Signal) 、变 量 ( Variable) 、常 量 ( Con- st仅在 Process 内可见; 常量代表一个具体的值。
TYPE TIME IS RANGE <implementation defined> UNITS
fs; - - femtosecond ps = 1000 fs; - - picosecond ns = 1000 ps; - - nanosecond us = 1000 ns; - - micr osecond ms = 1000 us; - - millisecond sec = 1000 ms; - - second min = 60 sec; - - minute hr = 60 min; - - hour END UNITS;
2006年第 1 期
福建电脑
109
高级程序设计语言和硬件描述语言 VHDL 的数据类型比较
李 杰 1 韩建敏 2
(1.郑州大学体育学院 河南 郑州 450044; 2.河南经贸职业学院 河南 郑州 450043)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
Declarations of wires, regs and other variables
Data flow statements ( assign )
Instantiation of lower level modules
Tasks and functions
Always and initial blocks, All behavioral statements go in these blocks.
Verilog HDL硬件描述语言的主要能力:
➢ 基本逻辑门,例如and、or和nand等都内置在语言中。 ➢ 用户定义原语(UDP)创建的灵活性。用户定义的原语既可以是组
合逻辑原语,也可以是时序逻辑原语。 ➢ 开关级基本结构模型,例如pmos和nmos等也被内置在语言中。 ➢ 提供显式语言结构指定设计中端口到端口的时延及路径时延和设计
endmodule
第9页/共34页
这5个组件的 排列顺序是 任意的,可 以选择其中 的一个或几 个组件构成 一个Verilog 程序。
时延
Verilog HDL模型中的所有时延都根据单位定义。 下面是带时延的连续赋值语句实例:
assign #2 Sum = A ^ B; #2指2个时间单位。
如果没有说明时延时间单位,Verilog HDL模拟器会 指定一个缺省时间单位。
目录
SOC设计概述 可编程逻辑器件 硬件描述语言及其程序设计方法 SOC的设计-基本工具和方法 SOC设计实例
第1页/共34页
Verilog HDL 简介
Verilog HDL是一种硬件描述语言,用于从算法级、门级到 开关级的多种抽象设计层次的数字系统建模。
Verilog HDL语言具有下述描述能力:
IEEE Verilog HDL标准中没有规定缺省时间单位。
第10页/共34页
数据流描述
a
一般使用连续赋值assign语句描述,
out1
主要用于组合逻辑电路建模。
b
module mux2_1(out1, a, b, sel) ; output out1; input a, b; input sel;
一个设计的结构可使用开关级原语、门级原语和用 户定义的原语方式描述;
设计的数据流行为使用连续赋值语句进行描述; 时序行为使用过程结构描述。 一个模块可以在另一个模块中使用。
第7页/共34页
Verilog程序的结构
Verilog程序由关键词module和endmodule进行定义 Verilog HDL 大小写敏感
的时序检查。 ➢ 可采用三种不同方式或混合方式对设计建模。这些方式包括:行为
描述方式--使用过程化结构建模;数据流方式--使用连续赋值 语句方式建模;结构化方式--使用门和模块实例语句描述建模。
第3页/共34页
Verilog HDL 简介
Verilog HDL硬件描述语言的主要能力(续):
➢ Verilog HDL中有两类数据类型:线网数据类型和寄存器数据类型。 线网类型表示构件间的物理连线,而寄存器类型表示抽象的数据存 储元件。
➢ 能够描述层次设计,可使用模块实例结构描述任何层次。 ➢ 设计的规模可以是任意的;语言不对设计的规模(大小)施加任何
限制。 ➢ Verilog HDL不再是某些公司的专有语言而是IEEE标准。 ➢ 人和机器都可以阅读Verilog语言,因此它可以作为EDA的工具和设
计者之间的交互语言。
第4页/共34页
➢ 设计的行为特性 ➢ 设计的数据流特性 ➢ 设计的结构组成 ➢ 包含响应监控和设计验证方面的时延和波形产生机制。
Verilog HDL语言不仅定义了语法,而且对每个语法结构都 定义了清晰的模拟、仿真语义。因此,用这种语言编写的模 型能够使用Verilog仿真器进行验证。
第2页/共34页
Verilog HDL 简介
sel
module mux2_1(out1, a, b, sel) ; output out1; input a, b; input sel;
➢ 能够使用内置开关级原语在开关级对设计完整建模。 ➢ 同一语言可用于生成模拟激励和指定测试的验证约束条件,例如输
入值的指定。 ➢ Verilog HDL能够监控模拟验证的执行,即模拟验证执行过程中设计
的值能够被监控和显示。
第5页/共34页
Verilog HDL 简介
Verilog HDL硬件描述语言的主要能力(续):
➢ 在行为级描述中,Verilog HDL不仅能够在RTL级上进行设计描述, 而且能够在体系结构级描述及其算法级行为上进行设计描述。
➢ 能够使用门和模块实例化语句在结构级进行结构描述。 ➢ Verilog HDL还具有内置逻辑函数,例如&(按位与)和 | (按位或)。 ➢ 对高级编程语言结构,例如条件语句、情况语句和循环语句,语言
module name (port_list);
port declarations
data type declarations functionality
timing specification
endmodule
第8页/共34页
Verilog程序的组成部分
module Name, port list, port declarations(if ports present) parameters(optional),
Verilog HDL 简介
Verilog HDL硬件描述语言的主要能力(续):
➢ Verilog HDL语言的描述能力能够通过使用编程语言接口(PLI)机 制进一步扩展。PLI是允许外部函数访问Verilog模块内信息、允许 设计者与模拟器交互的例程集合。
➢ 设计能够在多个层次上加以描述,从开关级、门级、寄存器传输级 (RTL)到算法级,包括进程和队列级。
中都可以使用。 ➢ 可以显式地对并发和时进行建模。 ➢ 提供强有力的文件读写能力。 ➢ 语言在特定情况下是非确定的,即在不同的模拟器上模型可以产生
不同的结果;例如,事件队列上的事件顺序在标准中没有定义。
第6页/共34页
Verilog程序的结构
模块是Verilog的基本描述单位,用于描述某个设计 的功能或结构及其与其他模块通信的外部端口。