VHDL基础讲解.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
端口模式有以下几种类型:(方框代表一个设计实体) in out buffer inout 4.3.1 顺序语句 顺序语句只能出现在进程(Process)和子程序(函数和过程)中。在VHDL中,一个进程是由一系列顺序语句构成的,在同一设计实体中,所有的进程是并行执行的。然而任一给定的时刻内,在每一个进程内,只能执行一条顺序语句。VHDL有如下六类基本顺序语句:赋值语句、转向控制语句、等待语句、子程序调用语句、返回语句和空操作语句。 1. 顺序赋值语句 顺序赋值语句的功能就是将一个值或一个表达式的运算结果传递给某一数据对象,如信号或变量,或由此组成的数组。VHDL设计实体内的数据传递以及对端口界面外部数据的读/写都必须通过赋值语句的运行来实现。 顺序赋值语句包括信号赋值语句和变量赋值语句。 变量:= 赋值源; 信号= 赋值源; 在信号赋值中,需要注意的是,当在同一进程中,同一信号赋值目标有多个赋值源时,信号赋值目标获得的是最后一个赋值源的赋值,其前面相同的赋值目标则不作任何变化。 2. IF语句 4.3.2 并行语句 相对于传统的软件描述语言,并行语句结构是最具VHDL特色的。在VHDL中,并行语句具有多种语句格式,各种并行语句在结构体中的执行是同步进行的,或者说是并行运行的,其执行方式与书写的顺序无关。在执行中,并行语句之间可以有信息往来,也可以是相互独立、互不相关的。 1. 并行信号赋值语句 并行信号赋值语句有三种形式:简单信号赋值语句、条件信号赋值语句和选择信号赋值语句。 这三种信号赋值语句的共同点是:赋值目标必须都是信号,所有赋值语句与其他并行语句一样,在结构体内的执行是同时发生的,与它们的书写顺序和是否在块语句中没有关系。 2. 进程语句 【例】全加器的VHDL描述 if(j=‘0’ and k=‘1’) then q_s=‘0’; qb_s=‘1’; elsif (j=‘1’ and k=‘0’) then q_s=‘1’; qb_s=‘0’; elsif (j=‘1’ and k=‘1’) then q_s=not q_s; qb_s=not qb_s; end if; end if ; q=q_s; qb=qb_s; end process; end architecture art; 2. 同步复位的D触发器 library ieee; use ieee.std_logic_1164.all; entity syndcfq is port(d, clk,reset:in std_logic; q:out std_logic); end entity syndcfq; architecture art of syndcfq is begin process(clk) is begin if(clkevent and clk=‘1’) then if(reset=‘0’) then q=‘0’; --时钟边沿到来且有复位信号,触发器被复位 else q=d; end if; end if; end process; end architecture art; 3. 异步复位/置位的D触发器 library ieee; use ieee.std_logic_1164.all; entity asyndcfq is port(clk,d,preset,clr:in std_logic; q:out std_logic); end entity asyndcfq; architecture art of asyndcfq is begin process(clk,preset,clr) is begin if(preset=1) then --置位信号为1,则触发器被置位 q=1; elsif(clr=1) then --复位信号为1,则触发器被复位 q=0; elsif(clkevent and clk=‘1

文档评论(0)

好文精选 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档