河北保定人 2022-10-15 08:27 采纳率: 100%
浏览 12
已结题

verilog 堵塞和非堵塞的区别

这两段代码一个是用了堵塞一个是用了非堵塞,这两个模块有什么区别?
综合后的电路这俩模块有区别吗?


module cntx1
(
    input                clk,
    input                rst_n,
    output    reg[4:0]    cnt_out
);
    always@(posedge clk)
    begin
        if( rst_n==0 )
            cnt_out    <= 5'b0;
        else
            cnt_out    <= cnt_out+1'b1;
    end
    
endmodule
module cntx2
(
    input                clk,
    input                rst_n,
    output    reg[4:0]    cnt_out
);
    always@(posedge clk)
    begin
        if( rst_n==0 )
            cnt_out    = 5'b0;
        else
            cnt_out    = cnt_out+1'b1;
    end
    
endmodule

展开全部

  • 写回答

1条回答 默认 最新

  • 老皮芽子 2022-10-15 08:34
    关注

    这俩模块虽然是用了堵塞和非堵塞的赋值,但是在 always@(posedge clk) 模块中没有迭代,而是在时钟的边沿触发。
    这俩模块没区别。综合后的电路也会使一样的没区别。
    在 always@(posedge clk) 中不建议用 = 堵塞赋值,这会影响一些计算的分析。
    一般在 always@(*) 组合逻辑里,一些有迭代计算时可以用 = 堵塞赋值

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 12月5日
  • 已采纳回答 11月28日
  • 创建了问题 10月15日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部