阻塞与非阻塞

本文详细介绍了Verilog编程中的阻塞赋值(=)和非阻塞赋值(<=)的区别。阻塞赋值用于组合逻辑,非阻塞赋值用于时序逻辑,遵循特定的编程原则以避免冒险竞争。通过实例展示了两者在代码、电路及仿真中的行为差异,并提供了测试波形图作为验证。理解这两种赋值方式对于Verilog综合后仿真的正确性至关重要。
摘要由CSDN通过智能技术生成

阻塞赋值与非阻塞赋值:

1.符号

阻塞赋值“=”(组合逻辑电路),非阻塞赋值“<=”(时序逻辑电路);

2.Verilog模块编程的8个原则:

(1) 时序电路建模时,用非阻塞赋值。

(2) 锁存器电路建模时,用非阻塞赋值。

(3) 用always块建立组合逻辑模型时,用阻塞赋值。

(4) 在同一个always块中建立时序和组合逻辑电路时,用非阻塞赋值。

(5) 在同一个always块中不要既用非阻塞赋值又用阻塞赋值。

(6) 不要在一个以上的always块中为同一个变量赋值。

(7) 用$strobe系统任务来显示用非阻塞赋值的变量值。

(8) 在赋值时不要使用#0延时。

在编写时牢记这八个要点可以为绝大多数的Verilog用户解决在综合后仿真中出现的90-100% 的冒险竞争问题。

3.概念区别

阻塞语句:指在同一个always块中,其后面的赋值语句从概念上是在前一条赋值语句结束后开始赋值的。

非阻塞语句:首先计算语句块内部所有右边表达式(RHS)的值,然后完成对左边寄存器变量的赋值操作。

4.代码区别

begin

    B=A;

    C=B+1;

end

上述代码先将A的值赋值给B,C的值是A+1;

begin

    B<=A;

    C<=B+1;

end

上述代码的最终结果是:将A赋值给了B,但是C的值是B原来的值+1。因为最先计是的是右边的表达式。

5.电路区别

阻塞型:

moduleblocking(clk, a, b, c);

       output [3:0] b,c;

       input [3:0] a;

       input clk;

       reg   [3:0] b,c;

      

       always@(posedge clk) begin

              b = a;

              c = b;

              $display("Blocking: a = %d, b= %d, c = %d.", a, b, c);

       end

endmodule

电路原理图:
在这里插入图片描述

modulenon_blocking(clk, a, b, c);

       output [3:0] b,c;

       input [3:0] a;

       input clk;

       reg   [3:0] b,c;

      

       always@(posedge clk) begin

              b <= a;

              c <= b;

              $display("Non_Blocking: a =%d, b = %d, c = %d.", a, b, c);

       end

endmodule

电路原理图:
在这里插入图片描述

TestBench:

`timescale1ns/1ns

 

moduleblocking_test;

       wire [3:0] b1, c1, b2, c2;

       reg [3:0] a;

       reg clk;

      

       initial begin

              clk = 0;

              forever #50 clk = ~clk;

       end

      

       initial begin

              a = 4'h3;

              $display("______________________");

              #100 a = 4'h7;

              $display("______________________");

              #100 a = 4'hf;

              $display("______________________");

              #100 a = 4'ha;

              $display("______________________");

              #100 a = 4'h2;

              $display("______________________");

              #100$display("______________________");

              $stop;

       end

      

       non_blocking        u1(clk, a, b2, c2);

       blocking               u2(clk,a, b1, c1);

      

endmodule

仿真波形图:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值