VHDL及数字集成电路设计VHDL1-4.ppt

  1. 1、本文档共51页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
VHDL及数字集成电路设计VHDL1-4

进程语句的对比: always @ (敏感条件) begin … 顺序语句 … end 1.4 数字系统的进程表达 process process(敏感量表) 变量设置 begin … 顺序语句; … end process; VHDL Verilog HDL 进程语句的对比: module port设置 wire设置—always外赋值 reg设置—always中赋值 always @ (敏感条件) begin 顺序语句 end 1.4 数字系统的进程表达 process entity port设置 architeture signal设置 process(敏感量表) variable设置 begin 顺序语句; end process; VHDL Verilog HDL 赋值语句的对比: 连续赋值语句 … always @ (敏感条件) begin 非阻塞赋值语句 阻塞赋值语句 end 1.4 数字系统的进程表达 process architeture signal赋值语句 … process(敏感量表) begin 信号赋值语句 变量赋值语句 end process; … VHDL Verilog HDL 连续赋值:独立的并行语句,为信号赋值 assign y = f (a,b,c); 非阻塞赋值:always内的赋值,具有信号赋值特点,所有赋值在子程序结束时才实现 y = f (a,b,c); 阻塞赋值: always内的赋值,具有变量赋值特点,根据语句排列顺序及时实现 y = f(a,b,c); 1.4 数字系统的进程表达 process 赋值语句的对比: VHDL: 使用signal和variable将硬件连接与数据存储概念明确区分,而对信号赋值的控制性则采用进程外的并行赋值和进程内的顺序赋值进行区分; Verilog HDL: 使用wire和reg将直接赋值对象与受控赋值对象区分开,而对reg则采用always内的非阻塞赋值和阻塞赋值区分其是否具有硬件连接意义;为避免驱动冲突,应谨慎使用非阻塞赋值。 1.4 数字系统的进程表达 process 赋值语句的对比: 由于进程内部采用软件编程,则可以将软件语言中各种运算控制方式引入到运算的表达中: 条件分支:二分支控制 选择分支:多选择控制 循环控制:有限循环、条件循环 wait控制:条件、延时 寄存器控制:边沿检测控制 进程中对运算的控制 1.4 数字系统的进程表达 process if 布尔表达式1 then 顺序语句1 elsif 布尔表达式2 then 顺序语句2 …… elsif 布尔表达式n then 顺序语句n else 顺序语句(n+1) end if; 条件判断语句:if-then-else 语句 1.4 数字系统的进程表达 process 条件判断语句:if-then-else 语句 1.4 数字系统的进程表达 process 每组then_else在运算流程中形成一个二分支路由判断,功能类似条件赋值语句when_else; 这种分支架构可以重叠进行,形成运算网络架构,也可以对运算进行优先排序; 当某个then表达对信号的赋值,缺少else的对应时,则表达对该信号进行寄存,可以综合形成寄存器。 条件判断语句特点 1.4 数字系统的进程表达 process 例:优先编码器的表达 architecture rtl of priority is begin process (a) begin if a(7)=1 then y=111; elsif a(6)=1 then y=110; elsif a(5)=1 then y=101; elsif a(4)=1 then y=100; elsif a(3)=1 then y=011; elsif a(2)=1 then y=010; elsif a(1)=1 then y=001; else y=000; end if; end process;end rtl; 1.4 数字系统的进程表达 process case 表达式 is when 选择值1 = 顺序语句1; when 选择值2 = 顺序语句2; when others = 顺序语句3; end case; 选择分支语句:case 语句 1.4 数字系统的进程表达 process 例:7段译码器 architecture rtl of seg7

文档评论(0)

yaocen + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档