Commentary (#2510)

This commit is contained in:
Wilson Snyder 2020-08-24 08:58:33 -04:00
parent f7f3d3fd43
commit be8f1a25c6

View File

@ -4199,17 +4199,7 @@ default as a code style warning.
=item BLKANDNBLK =item BLKANDNBLK
BLKANDNBLK is an error that a variable comes from a mix of blocking and BLKANDNBLK is an error that a variable comes from a mix of blocking and
non-blocking assignments. Generally, this is caused by a register driven non-blocking assignments.
by both combo logic and a flop:
always @ (posedge clk) foo[0] <= ...
always @* foo[1] = ...
Simply use a different register for the flop:
always @ (posedge clk) foo_flopped[0] <= ...
always @* foo[0] = foo_flopped[0];
always @* foo[1] = ...
This is not illegal in SystemVerilog, but a violation of good coding This is not illegal in SystemVerilog, but a violation of good coding
practice. Verilator reports this as an error, because ignoring this warning practice. Verilator reports this as an error, because ignoring this warning
@ -4220,6 +4210,24 @@ BLKANDNBLK" metacomment or the -Wno-BLKANDNBLK option) when one of the
assignments is inside a public task, or when the blocking and non-blocking assignments is inside a public task, or when the blocking and non-blocking
assignments have non-overlapping bits and structure members. assignments have non-overlapping bits and structure members.
Generally, this is caused by a register driven by both combo logic and a
flop:
logic [1:0] foo;
always @ (posedge clk) foo[0] <= ...
always @* foo[1] = ...
Simply use a different register for the flop:
logic [1:0] foo;
always @ (posedge clk) foo_flopped[0] <= ...
always @* foo[0] = foo_flopped[0];
always @* foo[1] = ...
Or, this may also avoid the error:
logic [1:0] foo /*verilator split_var*/;
=item BLKSEQ =item BLKSEQ
This indicates that a blocking assignment (=) is used in a sequential This indicates that a blocking assignment (=) is used in a sequential