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

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 16:34
    关注

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

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

报告相同问题?

问题事件

  • 系统已结题 12月6日
  • 已采纳回答 11月28日
  • 创建了问题 10月15日

悬赏问题

  • ¥15 Arduino无法同时连接多个hx711模块,如何解决?
  • ¥50 需求一个up主付费课程
  • ¥20 模型在y分布之外的数据上预测能力不好如何解决
  • ¥15 processing提取音乐节奏
  • ¥15 gg加速器加速游戏时,提示不是x86架构
  • ¥15 python按要求编写程序
  • ¥15 Python输入字符串转化为列表排序具体见图,严格按照输入
  • ¥20 XP系统在重新启动后进不去桌面,一直黑屏。
  • ¥15 opencv图像处理,需要四个处理结果图
  • ¥15 无线移动边缘计算系统中的系统模型