第八部分_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文档。上传文档
查看更多
第八部分_VHDL基本语句

EDA技术实用教程;8.1 顺序语句; 在用VHDL语言描述系统硬件行为时,按语句执行顺序对其进行分类,可分为顺序语句和并行语句(或称并发语句)。 顺序语句:指每条顺序语句的执行(指仿真执行)顺序是与它们的书写顺序基本一致,它们只能出现在进程和子程序(包括函数和过程)中。 VHDL有六类基本顺序语句:赋值语句、流程控制语句、等待语句、子程序调用语句、返回语句、空操作语句。;一、赋值语句 1、功能:将一个值或一个表达式的运算结果传递给某一数据对象,如信号、变量或由此组成的数组。 2、分类和组成:分为信号赋值语句和变量赋值语句两种,每一种赋值语句都由三个基本部分组成,即赋值目标、赋值符号、赋值源。 (1)赋值目标:是所赋值的受体,其基本元素只能是信号或变量,但表现形式可以有多种,如文字、标识符、数组等。 (2)??值符号:只有两种,信号赋值符号是“=”,变量赋值符号是“:=”。 (3)赋值源:是赋值的主体,它可以是一个数值,也可以是一个逻辑或运算表达式。 VHDL规定:赋值目标与赋值源的数据类型必须严格一致。;; 注: 10 IF语句中至少应有一个条件句,“条件句”可是一个BOOLEAN类型的标识符,如IF al THEN …,或是一个判别表达式,如IF ab+1 THEN…,判别表达式输出的值,即判断结果的数据类型是BOOLEAN。 20 IF语句根据条件句产生的判断结果是true或是false,有条件地选择执行其后的顺序语句。;;多条件选择值的一般表达式为: 选择值 [ |选择值 ]; 注:使用CASE语句注意事项: (1)条件句的选择值必须在表达式的取值范围内; (2)除非所有条件句中的选择值能完整覆盖CASE语句中表达式的取值,否则最末一个条件句中的选择必须用“OTHERS”表示,它代表已给的所有条件句中未能列出的其它可能的取值。关键词OTHERS只能出现一次,且只能作为最后一种条件取值。 (3)CASE语句中每一条件句的选择值只能出现一次,不能有相同选择值的条件语句出现。 (4)CASE语句执行中必须选中且只能选中所列条件语句中的一条(这表明CASE语句中至少包含一个条件语句)。 例9-1描述的4选1选择器是用IF语句和CASE语句共同完成的,它是根据4位输入码确定输出中哪一位输出为1,选择表达式的数据类型是整数型。; 【例8-1】 LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; ENTITY mux41 IS PORT (s4,s3, s2,s1 : IN STD_LOGIC; z4,z3, z2,z1 : OUT STD_LOGIC); END mux41; ARCHITECTURE activ OF mux41 IS SIGNAL sel : INTEGER RANGE 0 TO 15; BEGIN ;PROCESS (sel ,s4,s3,s2,s1 ) BEGIN sel= 0 ; -- 输入初始值 IF (s1 =1) THEN sel = sel+1 ; ELSIF (s2 =1) THEN sel = sel+2 ; ELSIF (s3 =1) THEN sel = sel+4 ; ELSIF (s4 =1) THEN sel = sel+8 ; ELSE NULL; -- 注意,这里使用了空操作语句 END IF ; z1=0 ; z2=0; z3=0; z4=0;--输入初始值 CASE sel WHEN 0 = z1=1 ; -- 当sel=0时选中 WHEN 1?3 = z2=1 ; -- 当sel为1或3时选中 WHEN 4 To 7?2 = z3=1;-- 当sel为2、4、5、6或7时选中 WHEN OTHERS = z4=1 ; -- 当sel为8~15中任一值时选中 END CASE ; END PROCESS ; END activ ;;【例8-2】CASE语句使用中容易发生的错误 SIGNAL value : INTEGER RANGE 0 TO 15; SIGNAL out1 : STD_LOGIC ; ... CASE value

文档评论(0)

盼储储time + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档