- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章 硬件描述语言VHDL基础.doc
硬件描述语言VHDL基础
概述
VHDL与高级语言的区别:VHDL的程序的一些并行语句可以自动重复执行,不需要循环语句,而且许多语句的执行不以书写的顺序来执行,而是并发执行的。
VHDL程序结构
一、基本结构及举例
一个完整的VHDL设计文件,包含实体说明(Entity)、结构体(Architecture)、配置(Configuration)、程序包(Package)和库(Library)五个部分。
其中,Package和Library都用来说明需要使用的外部资源,Package中说明自定义(或别人定义)的程序包,而Library则说明已经经过编译好的程序包。
Entity描述输入/输出端口,Architecture则说明实体的内部结构或功能,当有多个Architecture的时候要使用Configuration来指定哪一个起作用。
LIBRARY IEEE;
USE IEEE.STD_LOGIC_1164.ALL;
ENTITY and2 IS
PORT(
A,B: IN STD_LOGIC;
L: OUT STD_LOGIC);
END and2;
ARCHITECTURE behave OF and2 IS
BEGIN
L=A AND B;
END behave;
二、实体说明
格式:
ENTITY 实体名IS
[GENERIC(类属表);]
[PORT(端口表);]
END [ENTITY][实体名];
注意:实体名一定要与设计文件名相同,否则无法编译。
(注:上面使用[ ]的部分表示可以没有,使用()的部分表示必须有,下同)
其中,GENERIC定义本实体中使用的局部常数,使用较少。
一般格式为:GENERIC(常数名表:数据类型[:=设定值];…);
如:GENERIC (m:TIME:=3ns);
A=B AND C AFTER m;
PORT则说明实体的输入/输出信号及其模式,模式有IN(输入)、OUT(输出)、INOUT(输入输出)和BUFFER(输出并向内部反馈)四种
一般格式为:PORT(端口名表:端口模式 数据类型;…);
三、结构体及其描述
1、结构体的格式:
ARCHITECTURE 结构体名 OF 实体名 IS
[说明语句]
[BEGIN
并行语句;]
END [ARCHITECTURE] [结构体名];
说明语句用来说明本结构体要用到的信号、类型、常数、元件、函数和过程等。
并行语句则说明了实体的具体结构或功能,有五种:块语句(BLOCK)、进程语句(PROCESS)、信号赋值语句、子程序(含过程(PROCEDURE)和函数(FUNCTION))、元件例化语句(COMPONENT)
2、结构体的描述方式
1),行为描述
ARCHITECTURE behave OF mux2 IS
BEGIN
Y=Input(0) WHEN sel=’1’ ELSE
Input(1);
END behave;
2),数据流描述
ARCHITECTURE rtl OF mux2 IS
SIGNAL tmp1,tmp2,tmp3:STD_LOGIC;
BEGIN
tmp1=in0 AND sel;
tmp2=in1 AND (NOT sel);
tmp3=tmp1 OR tmp2;
y=tmp3;
END rtl;
3),结构描述
ARCHITECTURE archi OF rsff IS
COMPONENT nand2
PORT(a,b:IN BIT; c:OUT BIT);
END COMPONENT;
BEGIN
U1:nand2 PORT MAP(set,qbar,q);
U2:nand2 PORT MAP(q,reset,qbar);
END archi;
4),混合描述
VHDL的基本数据类型
数据对象
CONSTANT(常量)、VARIABLE(变量)、SIGNAL(信号)
说明格式:对象类别 表识符表:类型[:=初始值];
常量的值不能改变,而变量和信号的值可以改变,但两者有区别:
1),信号的声明在子程序、进程等的外部,变量声明则在内部;
2),在进程中,信号赋值是在进程结束时起作用,而变量赋值立即起作用;
3),信号赋值用=,变量赋值用:=。
二、数据类型
对数据的操作必须与其类型相匹配。
标准定义的数据类型有:INTEGER(整数)、REAL(实数)、CHARACTER(字符)、STRING(字符串)、BOOLEAN(布尔)、BIT(位)、BIT_VECTOR(位矢量)、TIME(时间)、NATURAL(自然数)、SEVERITY LEVEL(错误等级)。
常使用IEEE预定义的标准逻辑位与向量:STD_LOGIC,
您可能关注的文档
最近下载
- 摩托罗拉XiR_M3688_ServerManual维修手册.pdf VIP
- 奥西替尼杂质研究总结.pdf VIP
- 2024《格兰仕电器公司成本管理问题调查研究》8600字.docx VIP
- 中小学英语教师语音语调训练.ppt
- 《严格规范涉企行政检查》知识培训.pptx VIP
- MODS(多器官功能障碍综合征).ppt VIP
- 高中政治统编版必修一:(综合探究二)方向决定道路 道路决定命运.pptx
- VW75210-2 2011 (LV216-2) CN-电动汽车的高压屏蔽电缆要求和试验.pdf VIP
- 2022版小学《体育与健康课程标准》考试复习题库资料(含答案).pdf VIP
- 人工智能在邮政业的应用前景.pptx VIP
文档评论(0)