找回密码
 注册
关于网站域名变更的通知
查看: 127|回复: 2
打印 上一主题 下一主题

阻塞与非阻塞语句的区别

[复制链接]
  • TA的每日心情
    开心
    2022-1-29 15:03
  • 签到天数: 1 天

    [LV.1]初来乍到

    跳转到指定楼层
    1#
    发表于 2022-6-15 10:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

    EDA365欢迎您登录!

    您需要 登录 才可以下载或查看,没有帐号?注册

    x

    module DataBusOfBus(DataBus,link_bus,write);

    inout[11:0] DataBus;

    input link_bus;

    reg [11:0] outsigs;

      ^4 |" r7 w/ ~0 X1 T6 X; C

    assign DataBus=(link_bus)?outsigs:12'hzzz;

    ) K6 [7 q  }3 w9 l4 J  @

    always @(posedge write)

              begin

               outsigs<=DataBus*5;

              end


    2 B9 U' I% a# L. T, a" f

    endmodule

    3 f- u/ n, `6 q; D6 Q3 ?2 Z; t- m

    为什么assign用的是阻塞赋值而always中用的是非阻塞?

    如果assign中的阻塞赋值换为非阻塞赋值以及always中的非阻塞换为阻塞会有出现什么结果?

    8 i4 g; t7 a2 w1 |0 }- Q. N
  • TA的每日心情

    1643439839
  • 签到天数: 1 天

    2#
    发表于 2022-6-15 10:53 | 只看该作者

    VERILOG 语法规定:

    assign 只能用于阻塞赋值;

    aways 模块中即可用阻塞赋值也可以非阻塞赋值,根据电路设计需要;

    需要说明的是:

    阻塞赋值 立即执行(=);

    非阻塞赋值,等到模块结束后,同时执行;

    assign 不能用于非阻塞赋值!

  • TA的每日心情
    开心
    2022-1-29 15:04
  • 签到天数: 1 天

    [LV.1]初来乍到

    3#
    发表于 2022-6-15 11:09 | 只看该作者
    在用verilog设计电路的时候,对于阻塞非阻塞记住下面这两点:- J' F3 J. ]  h" e% E
    1.用always描述组合逻辑时用阻塞语句(建议还是用assign语句描述组合逻辑);
    3 x' `; g+ ?( G: U- @0 ?( ~2.描述时序逻辑电路用非阻塞。. M/ }& f' T) g/ o/ c& P
    ps:同一个always块中,最好不要同时用阻塞和非阻塞语句。
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-7-26 14:29 , Processed in 0.109375 second(s), 23 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表