You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Checks that no forbidden system tasks or functions are used. These consist of the following functions: $psprintf, $random, and $dist_*. As well as non-LRM function $srandom. See [Style: forbidden-system-functions].
When I use $random in a SystemVerilog file, Verible prints this warning:
1. $random is a forbidden system function or task, please use $urandom instead [Style: forbidden-system-functions][invalid-system-task-function]
I'm curious as to why it's discouraged to use $random and instead use $urandom. Forgive me, I'm pretty new to verilog & systemverilog. Thanks for the clarification!
The text was updated successfully, but these errors were encountered:
I think that was mostly a request by DV engineers that like to inject better ways to get test vector, though it would probably good to have that as an explicit style guide somewhere so that it is easy to refer to.
Quote from the style guide:
"$random and $dist_*: these functions should not be used as they are not part of the SystemVerilog random stability model and may break simulation reproducibility. Use $urandom or randomize() instead."
invalid-system-task-function
states:When I use
$random
in a SystemVerilog file, Verible prints this warning:I'm curious as to why it's discouraged to use
$random
and instead use$urandom
. Forgive me, I'm pretty new to verilog & systemverilog. Thanks for the clarification!The text was updated successfully, but these errors were encountered: