第四章 硬件描述语言VHDL基础.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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,

文档评论(0)

dzzj200808 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档