mirror of
https://github.com/verilator/verilator.git
synced 2025-01-22 14:24:18 +00:00
49c90ecbce
Some cases of warnings about the use of blocking and non-blocking assignments in combinational vs sequential processes were suppressed in a way that is inconsistent with the *actual* current execution model of Verilator. Turning these back on to, well, warn the user that these might cause unexpected results. V5 will clean these up, but until then err on the side of caution. Fixes #864.
14 lines
919 B
Plaintext
14 lines
919 B
Plaintext
%Warning-COMBDLY: t/t_lint_latch_bad_2.v:13:10: Non-blocking assignment '<=' in combinational logic process
|
|
: ... This will be executed as a blocking assignment '='!
|
|
13 | o <= b;
|
|
| ^~
|
|
... For warning description see https://verilator.org/warn/COMBDLY?v=latest
|
|
... Use "/* verilator lint_off COMBDLY */" and lint_on around source to disable this message.
|
|
*** See https://verilator.org/warn/COMBDLY before disabling this,
|
|
else you may end up with different sim results.
|
|
%Warning-LATCH: t/t_lint_latch_bad_2.v:11:4: Latch inferred for signal 'o' (not all control paths of combinational always assign a value)
|
|
: ... Suggest use of always_latch for intentional latches
|
|
11 | always @(a or b)
|
|
| ^~~~~~
|
|
%Error: Exiting due to
|