3
0
Fork 0
mirror of https://github.com/YosysHQ/sby.git synced 2025-04-05 22:14:08 +00:00

Add documentation for [tasks] section

This commit is contained in:
Clifford Wolf 2018-03-05 13:09:40 +01:00
parent 92b247260a
commit 231d06b7c5

View file

@ -4,8 +4,104 @@ Reference for .sby file format
A ``.sby`` file consists of sections. Each section start with a single-line A ``.sby`` file consists of sections. Each section start with a single-line
section header in square brackets. The order of sections in a ``.sby`` file section header in square brackets. The order of sections in a ``.sby`` file
is irrelevant, but by convention the usual order is ``[options]``, is for the most part irrelevant, but by convention the usual order is
``[engines]``, ``[script]``, and ``[files]``. ``[tasks]``, ``[options]``, ``[engines]``, ``[script]``, and ``[files]``.
Tasks section
-------------
The ``[tasks]`` section can be used to configure multiple verification tasks in only
one ``.sby`` file. Each line in the ``[tasks]`` section configures one task. For example:
.. code-block:: text
[tasks]
task1 task_1_or_2 task_1_or_3
task2 task_1_or_2
task3 task_1_or_3
Each task can be assigned additional group aliases, such as ``task_1_or_2``
and ``task_1_or_3`` in the above example.
A task can be specified as additional command line argument when calling
``sby`` on a ``.sby`` file:
.. code-block:: text
sby example.sby task2
If no task is specified then the configuration for the first task in the
``[tasks]`` section is used.
After the ``[tasks]`` section individual lines can be specified for specific
tasks or task groups:
.. code-block:: text
[options]
task_1_or_2: mode bmc
task_1_or_2: depth 100
task3: mode prove
If the tag ``<taskname>:`` is used on a line by itself then the following block
until the next blank line is conditional.
.. code-block:: text
[options]
task_1_or_2:
mode bmc
depth 100
task3:
mode prove
The tag ``~<taskname>:`` can be used for a line or block that should not be used when
the given task is active:
.. code-block:: text
[options]
~task3:
mode bmc
depth 100
task3:
mode prove
The following example demonstrates how to configure safety and liveness checks for all
combinations of some host implementations A and B and device implementations X and Y:
.. code-block:: text
[tasks]
prove_hAdX prove hostA deviceX
prove_hBdX prove hostB deviceX
prove_hAdY prove hostA deviceY
prove_hBdY prove hostB deviceY
live_hAdX live hostA deviceX
live_hBdX live hostB deviceX
live_hAdY live hostA deviceY
live_hBdY live hostB deviceY
[options]
prove: mode prove
live: mode live
[engines]
prove: abc pdr
live: aiger suprove
[script]
hostA: read_verilog hostA.v
hostB: read_verilog hostB.v
deviceX: read_verilog deviceX.v
deviceY: read_verilog deviceY.v
...
The ``[tasks]`` section must appear in the ``.sby`` file before the first
``<taskname>:`` or ``~<taskname>:`` tag.
Options section Options section
--------------- ---------------
@ -187,3 +283,13 @@ Files section
TBD TBD
File sections
-------------
TBD
Pycode blocks
-------------
TBD