Wednesday, 25 November 2015

BLOCKING AND NONBLOCKING ASSIGNMENT OPERATOR IN VERILOG

BLOCKING AND NONBLOCKING ASSIGNMENT OPERATOR:

                  The Verilog language has two forms of the procedural assignment statement: blocking and nonblocking. The two are distinguished by the = and <= assignment operators. The blocking assignment statement (= operator) acts much like in traditional programming languages. The whole statement is done before control passes on to the next statement. The non-blocking (<= operator) evaluates all the right-hand sides for the current time unit and assigns the left-hand sides at the end of the time unit. For example, the following Verilog program

EXAMPLE PROGRAM:
module blocking;
reg [0:7] A, B;
initial begin: init1
A = 3;
#1 A = A + 1; // blocking procedural assignment
B = A + 1;
$display("Blocking: A= %b B= %b", A, B );
A = 3;
#1 A <= A + 1; // non-blocking procedural assignment
B <= A + 1;
#1 $display("Non-blocking: A= %b B= %b", A, B );
end
endmodule

FOR MORE DETAILS CLICK HERE

No comments:

Post a Comment