forked from github/verilator
64 lines
1.5 KiB
ReStructuredText
64 lines
1.5 KiB
ReStructuredText
|
.. Copyright 2003-2022 by Wilson Snyder.
|
||
|
.. SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
||
|
|
||
|
.. _Example C++ Execution:
|
||
|
|
||
|
Example C++ Execution
|
||
|
=====================
|
||
|
|
||
|
We'll compile this SystemC example into a Verilated simulation binary. For
|
||
|
an example that discusses the next level of detail see :ref:`Example C++
|
||
|
Execution`.
|
||
|
|
||
|
.. include:: example_common_install.rst
|
||
|
|
||
|
Now, let's create an example Verilog file:
|
||
|
|
||
|
.. code-block:: bash
|
||
|
|
||
|
mkdir test_our
|
||
|
cd test_our
|
||
|
|
||
|
cat >our.v <<'EOF'
|
||
|
module our;
|
||
|
initial begin $display("Hello World"); $finish; end
|
||
|
endmodule
|
||
|
EOF
|
||
|
|
||
|
Now we run Verilator on our little example.
|
||
|
|
||
|
.. code-block:: bash
|
||
|
|
||
|
verilator --binary -j 0 -Wall our.v
|
||
|
|
||
|
Breaking this command down:
|
||
|
|
||
|
#. :vlopt:`--binary` telling Verilator to do everything needed to create a
|
||
|
simulation executable.
|
||
|
|
||
|
#. :vlopt:`-j` `0' to Verilate using use as many CPU threads as the machine
|
||
|
has.
|
||
|
|
||
|
#. :vlopt:`-Wall` so Verilator has stronger lint warnings
|
||
|
enabled.
|
||
|
|
||
|
#. An finally, :command:`our.v` which is our SystemVerilog design file.
|
||
|
|
||
|
And now we run it:
|
||
|
|
||
|
.. code-block:: bash
|
||
|
|
||
|
obj_dir/Vour
|
||
|
|
||
|
And we get as output:
|
||
|
|
||
|
.. code-block:: bash
|
||
|
|
||
|
Hello World
|
||
|
- our.v:2: Verilog $finish
|
||
|
|
||
|
Really, you're better off using a Makefile to run the steps for you so when
|
||
|
your source changes it will automatically run all of the appropriate steps.
|
||
|
To aid this Verilator can create a makefile dependency file. For examples
|
||
|
that do this see the :file:`examples` directory in the distribution.
|