2023-01-01 15:18:39 +00:00
|
|
|
.. Copyright 2003-2023 by Wilson Snyder.
|
2021-04-11 22:55:06 +00:00
|
|
|
.. SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
|
|
|
|
|
|
|
.. _Simulation Runtime Arguments:
|
|
|
|
|
|
|
|
Simulation Runtime Arguments
|
|
|
|
============================
|
|
|
|
|
|
|
|
The following are the arguments that may be passed to a Verilated
|
|
|
|
executable, provided that executable calls
|
2022-07-09 13:50:50 +00:00
|
|
|
:code:`VerilatedContext*->commandArgs(argc, argv)`.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
All simulation runtime arguments begin with "+verilator", so that the
|
|
|
|
user's executable may skip over all "+verilator" arguments when parsing its
|
|
|
|
command line.
|
|
|
|
|
|
|
|
Summary:
|
|
|
|
|
|
|
|
.. include:: ../_build/gen/args_verilated.rst
|
|
|
|
|
|
|
|
|
|
|
|
.. option:: +verilator+debug
|
|
|
|
|
|
|
|
Enable simulation runtime debugging. Equivalent to
|
|
|
|
:vlopt:`+verilator+debugi+4 <+verilator+debugi+\<value\>>`.
|
|
|
|
|
|
|
|
.. option:: +verilator+debugi+<value>
|
|
|
|
|
|
|
|
Enable simulation runtime debugging at the provided level.
|
|
|
|
|
|
|
|
.. option:: +verilator+error+limit+<value>
|
|
|
|
|
|
|
|
Set number of non-fatal errors (e.g. assertion failures) before exiting
|
|
|
|
simulation runtime. Also affects number of $stop calls needed before
|
|
|
|
exit. Defaults to 1.
|
|
|
|
|
|
|
|
.. option:: +verilator+help
|
|
|
|
|
|
|
|
Display help and exit.
|
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
.. option:: +verilator+prof+exec+file+<filename>
|
2021-04-11 22:55:06 +00:00
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
When a model was Verilated using :vlopt:`--prof-exec`, sets the
|
2021-04-11 22:55:06 +00:00
|
|
|
simulation runtime filename to dump to. Defaults to
|
2022-03-25 19:46:50 +00:00
|
|
|
:file:`profile_exec.dat`.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
.. option:: +verilator+prof+exec+start+<value>
|
2021-04-11 22:55:06 +00:00
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
When a model was Verilated using :vlopt:`--prof-exec`, the simulation
|
2021-04-11 22:55:06 +00:00
|
|
|
runtime will wait until $time is at this value (expressed in units of
|
|
|
|
the time precision), then start the profiling warmup, then
|
|
|
|
capturing. Generally this should be set to some time that is well within
|
|
|
|
the normal operation of the simulation, i.e. outside of reset. If 0, the
|
|
|
|
dump is disabled. Defaults to 1.
|
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
.. option:: +verilator+prof+exec+window+<value>
|
2021-04-11 22:55:06 +00:00
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
When a model was Verilated using :vlopt:`--prof-exec`, after $time
|
|
|
|
reaches :vlopt:`+verilator+prof+exec+start+\<value\>`, Verilator will
|
2021-04-11 22:55:06 +00:00
|
|
|
warm up the profiling for this number of eval() calls, then will capture
|
|
|
|
the profiling of this number of eval() calls. Defaults to 2, which
|
|
|
|
makes sense for a single-clock-domain module where it's typical to want
|
|
|
|
to capture one posedge eval() and one negedge eval().
|
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
.. option:: +verilator+prof+threads+file+<filename>
|
|
|
|
|
|
|
|
Deprecated. Alias for :vlopt:`+verilator+prof+exec+file+\<filename\>`
|
|
|
|
|
|
|
|
.. option:: +verilator+prof+threads+start+<value>
|
|
|
|
|
|
|
|
Deprecated. Alias for :vlopt:`+verilator+prof+exec+start+\<value\>`
|
|
|
|
|
|
|
|
.. option:: +verilator+prof+threads+window+<value>
|
|
|
|
|
2022-10-02 20:47:32 +00:00
|
|
|
Deprecated. Alias for :vlopt:`+verilator+prof+exec+window+\<value\>`
|
2022-03-25 19:46:50 +00:00
|
|
|
|
2021-09-27 02:51:11 +00:00
|
|
|
.. option:: +verilator+prof+vlt+file+<filename>
|
|
|
|
|
2022-03-25 19:46:50 +00:00
|
|
|
When a model was Verilated using :vlopt:`--prof-pgo`, sets the
|
2021-09-27 02:51:11 +00:00
|
|
|
profile-guided optimization data runtime filename to dump to. Defaults
|
|
|
|
to :file:`profile.vlt`.
|
|
|
|
|
2021-04-11 22:55:06 +00:00
|
|
|
.. option:: +verilator+rand+reset+<value>
|
|
|
|
|
2022-12-10 02:01:33 +00:00
|
|
|
When a model was Verilated using
|
|
|
|
:vlopt:`--x-initial unique <--x-initial>`, sets the simulation runtime
|
|
|
|
initialization technique. 0 = Reset to zeros. 1 = Reset to all-ones. 2
|
|
|
|
= Randomize. See :ref:`Unknown States`.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
.. option:: +verilator+seed+<value>
|
|
|
|
|
|
|
|
For $random and :vlopt:`--x-initial unique <--x-initial>`, set the
|
|
|
|
simulation runtime random seed value. If zero or not specified picks a
|
|
|
|
value from the system random number generator.
|
|
|
|
|
|
|
|
.. option:: +verilator+noassert
|
|
|
|
|
|
|
|
Disable assert checking per runtime argument. This is the same as
|
2022-07-09 13:50:50 +00:00
|
|
|
calling :code:`VerilatedContext*->assertOn(false)` in the model.
|
2021-04-11 22:55:06 +00:00
|
|
|
|
|
|
|
.. option:: +verilator+V
|
|
|
|
|
|
|
|
Shows the verbose version, including configuration information.
|
|
|
|
|
|
|
|
.. option:: +verilator+version
|
|
|
|
|
|
|
|
Displays program version and exits.
|