- 1、本文档共70页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
深入理解堵塞与非堵塞赋值
深入理解阻塞和非阻塞赋值的不同 概述 1、阻塞赋值对应的电路往往与触发沿没有关系,只与输入电平的变化有关系。阻塞赋值符号: = 2 非阻塞赋值对应的电路结构往往与触发沿有关系,只有在触发沿时才有可能发生赋值的情况。非阻塞赋值符号: = 阻塞赋值和非阻塞赋值 阻塞(Blocking)赋值方式 “= ”, 如 b = a; 赋值语句执行完后,块才结束。 b的值在赋值语句执行完后立刻就改变的。 非阻塞(Non_Blocking)赋值方式 “=”,如 b = a; 块结束后才完成赋值操作。 b的值并不是立刻就改变的。 这是一种比较常用的赋值方法(特别在编写可综合时序模块时)。 阻塞赋值 阻塞赋值操作符用等号(即 = )表示。阻塞赋值时先计算等 号右手方向(RHS)部分的值,这时赋值语句不允许任何别的 语句的干扰,直到现行的赋值完成时刻,即把RHS赋值给 LHS 的时刻,它才允许别的赋值语句的执行。 一般可综合的阻塞赋值操作在RHS不能设定有延迟,(即使 是零延迟也不允许)。若在RHS 加上延迟,则在延迟期间会阻 止赋值语句的执行, 延迟后才执行赋值,这种赋值语句是不可 综合的,在需要综合的模块设计中不可使用这种风格的代码。 阻塞赋值的执行可以认为是只有一个步骤的操作: 所谓阻塞的概念是指在同一个always块中,其后面的赋值语 句从概念上(即使不设定延迟)是在前一句赋值语句结束后再 开始赋值的。 非阻塞赋值 非阻塞赋值操作符用小于等于号 (即 = )表示。在赋值操 作时刻开始时计算非阻塞赋值符的RHS表达式,赋值操作时刻 结束时更新LHS。在计算非阻塞赋值的RHS表达式和更新LHS期 间,其他的Verilog语句,包括其他的Verilog非阻塞赋值语句 都能同时计算RHS表达式和更新LHS。非阻塞赋值允许其他的 Verilog语句同时进行操作。 非阻塞赋值的操作可以看作为两个步骤的过程: 1)在赋值时刻开始时,计算非阻塞赋值RHS表达式。 2)在赋值时刻结束时,更新非阻塞赋值LHS表达式。 非阻塞赋值操作只能用于对寄存器类型变量进行赋值,因此只 能用在“initial”块和“always”块等过程块中。非阻塞赋值不 允许用于连续赋值。 难点 1 何时使用非阻塞赋值,何时使用阻塞赋值才能设计出符合要求的电路。 2 在可综合风格的Verilog模块的设计中,为什么还要用非阻塞赋值,以及符合IEEE 标准的Verilog 仿真器究竟如何来处理非阻塞赋值的仿真。 本小节明确地提出可综合的Verilog模块编程在使用赋 值操作时应注意的要点,按照这些要点来编写代码就 可以避免在Verilog 仿真时出现冒险和竞争的现象 综合后波形对比 仿真波形对比 要 点 1 在描述组合逻辑的always块中用阻塞赋值,则综 合成组合逻辑的电路结构。 2 在描述时序逻辑的always块中用非阻塞赋值,则 综合成时序逻辑的电路结构。 RHS – 方程式右手方向的表达式或变量可分别缩写为: RHS表达式或RHS变量。 LHS – 方程式左手方向的表达式或变量可分别缩写为: LHS表达式或LHS变量。 深入理解阻塞的概念 阻塞赋值的执行可以认为是只有一个步骤的操作: 计算RHS并更新LHS,此时不能允许有来自任何其他Verilog 语句的干扰。 所谓阻塞的概念是指在同一个always块中,其后面的赋 值语句从概念上(即使不设定延迟)是在前一句赋值语句结 束后再开始赋值的。 如果在一个过程块中阻塞赋值的RHS变量正好是另一个过 程块中阻塞赋值的LHS变量,这两个过程块又用同一个时钟 沿触发,这时阻塞赋值操作会出现问题,即如果阻塞赋值的 次序安排不好,就会出现竞争。若这两个阻塞赋值操作用同 一个时钟沿触发,则执行的次序是无法确定的。 深入理解非阻塞的概念 非阻塞赋值的操作可以看作为两个步骤的过程: 1 在赋值时刻开始时,计算非阻塞赋值RHS表达式。 2 在赋值时刻结束时,更新非阻塞赋值LHS表达式。 非阻塞赋值操作只能用于对寄存器类型变量进行 赋值,因此只能用在“initial”块和“always”块等过程块中。非阻塞赋值不允许用于连续赋值。 阻塞赋值 非阻塞赋值 Verilog模块编程要点 1 时序电路建模时,用非阻塞赋值。 2 锁存器电路建模时,用非阻塞赋值。 3 用always块建立组合逻辑模型时,用阻塞赋值。 4 在同一个always块中建立时序和组合逻辑电路 时,用非阻塞赋值。 5 在同一个always块中不要既用非阻塞赋值又用阻 塞赋值。 6 不要在一个以上的always块中为同一个变量赋值。 7 用$strobe系统任务来显示用非阻塞赋值的变量
您可能关注的文档
- 流体力学第2章节一压强规律和平面压力.ppt
- 流行美产品规划和营销策略建议.ppt
- 流动图书车实施的方案.ppt
- 流行美整合营销传播的方案[完整版].ppt
- 活动四美术可以表现主观情感2演示课件.ppt
- 浅析扫瞄器解析与渲染.ppt
- 流通业-物流业与城市进展.ppt
- 流式视音频服务中的相关的技术初探.ppt
- 浅析风险与保险的联系.ppt
- 浅谈中考总复习写作练习.ppt
- CNAS-CL63-2017 司法鉴定-法庭科学机构能力认可准则在声像资料鉴定领域的应用说明.docx
- 12J7-3 河北《内装修-吊顶》.docx
- 12N2 河北省12系列建筑标准设计图集 燃气(油)供热锅炉房工程.docx
- 内蒙古 12S8 排水工程 DBJ03-22-2014.docx
- 山西省 12S10 12系列建筑标准设计 管道支架、吊架.docx
- 16J601-木门窗标准图集.docx
- 12J8 河北省12系列《 楼梯》.docx
- CNAS-GL37 2015 校准和测量能力(CMC)表示指南.docx
- CNAS-RL02-2016 能力验证规则.docx
- 津02SJ601 PVC塑料门窗标准.docx
文档评论(0)