verilator/.github/workflows
Geza Lore bc892deacc
Safely support non-overlapping blocking/non-blocking assignments (#6137)
The manual for the BLKANDNBLK warning describes that it is safe to
disable that error if the updated ranges are non-overlapping. This
however was not true (see the added t_nba_mixed_update* tests).

In this patch we change V3Delayed to use a new ShadowVarMasked
scheme for variables that have mixed blocking and non-blocking 
updates (or the FlagUnique scheme for unpacked variables), which
is in fact safe to use when the updated parts are non-overlapping.

Furthermore, mixed assignments are safe as far as scheduling is
concerned if either:

- They are to independent parts (bits/members/etc) (with this patch)
- Or if the blocking assignment is in clocked (or suspendable) logic.

The risk in scheduling is a race between the Post scheduled NBA
commit, and blocking assignments in combinational logic, which might
order incorrectly.

The second point highlights that we can handle stuff like this safely,
which is sometimes used in testbenches:

```systemverilog
always @(posedge clk) begin
    if ($time == 0) a = 0;
end

always @(posedge clk) begin
    if ($time > 0) a <= 2;
end
````

The only dangerous case is:

```systemverilog
always @(posedge clk) foo[idx] <= val;
assign foo[0] = bar;
```

Whit this patch, this will still resolve fine at run-time if 'idx' is
never zero, but might resolve incorrectly if 'idx' is zero.

With the above in mind, the BLKANDNBLK warning is now only issued if:

- We can't prove that the assignments are to non-overlapping bits
- And the blocking assignment is in combinational logic

These are the cases that genuinely require user attention to resolve.

With this patch, there are no more BLKANDNBLK warnings in the RTLMeter
designs.

Fixes #6122.
2025-06-28 20:45:45 +01:00
..
build.yml CI: Add actor to help cancel-in-progress group (#6097) 2025-06-16 17:44:06 -07:00
contributor.yml CI: Move coverage + contributor actions to 24.04 2025-05-13 22:21:21 -04:00
coverage.yml CI: Add variable to explicitly enable some GitHub workflows (#6021) 2025-05-18 21:13:37 -04:00
docker.yml CI: Reduce action permissions per best practices 2025-05-11 17:43:48 -04:00
format.yml Internals/CI: Format cmakefiles using mbake 2025-06-26 17:36:56 -04:00
msbuild.yml CI: Add actor to help cancel-in-progress group (#6097) 2025-06-16 17:44:06 -07:00
reusable-build.yml CI: Use reusable workflow, so tests start after build (#5901) 2025-03-29 15:09:32 -04:00
reusable-rtlmeter-build.yml Add RTLMeter GitHub workflows (#5948) 2025-04-19 15:42:33 +01:00
reusable-rtlmeter-run.yml Automatically publish scheduled RTLMeter results (#6074) 2025-06-10 13:06:05 +01:00
reusable-test.yml Internals: Apply make format-json format-yaml. No functional change. 2025-04-16 07:34:57 -04:00
rtlmeter.yml Safely support non-overlapping blocking/non-blocking assignments (#6137) 2025-06-28 20:45:45 +01:00