2022-09-28 13:04:14 +00:00
|
|
|
.. Copyright 2003-2022 by Wilson Snyder.
|
|
|
|
.. SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
|
|
|
|
2022-10-02 20:47:32 +00:00
|
|
|
.. _Example Create-Binary Execution:
|
2022-09-28 13:04:14 +00:00
|
|
|
|
2022-10-02 20:47:32 +00:00
|
|
|
Example Create-Binary Execution
|
|
|
|
===============================
|
2022-09-28 13:04:14 +00:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2022-10-02 20:47:32 +00:00
|
|
|
#. :vlopt:`-j` `0` to Verilate using use as many CPU threads as the machine
|
2022-09-28 13:04:14 +00:00
|
|
|
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.
|