mirror of
https://github.com/YosysHQ/yosys
synced 2025-04-06 17:44:09 +00:00
docs: reflowing selections doc
Combined presentation sections with appnote sections. Moved a bunch of Yosys one-liners in-line. Better reference in interactive investigation to memdemo as a part of advanced logic cone selection (esp. because the show commands use some of the advanced features)
This commit is contained in:
parent
c61ab7d627
commit
8335044c35
|
@ -434,16 +434,7 @@ of the module and wants to carefully read all the debug output created by the
|
||||||
commands in order to spot a problem. This kind of troubleshooting is much easier
|
commands in order to spot a problem. This kind of troubleshooting is much easier
|
||||||
if the circuit under investigation is encapsulated in a separate module.
|
if the circuit under investigation is encapsulated in a separate module.
|
||||||
|
|
||||||
.. literalinclude:: /APPNOTE_011_Design_Investigation/memdemo.v
|
Recall the ``memdemo`` design from :ref:`advanced_logic_cones`:
|
||||||
:caption: ``memdemo.v``, a demo circuit for demonstrating some advanced Yosys features
|
|
||||||
:language: verilog
|
|
||||||
:name: memdemo_v
|
|
||||||
|
|
||||||
Let's consider :numref:`memdemo_v`. It serves no purpose other than being a
|
|
||||||
non-trivial circuit for demonstrating some of the advanced Yosys features. We
|
|
||||||
synthesize the circuit using ``proc; opt; memory; opt`` and change to the
|
|
||||||
``memdemo`` module with ``cd memdemo``. If we type :cmd:ref:`show` now we see
|
|
||||||
the following diagram:
|
|
||||||
|
|
||||||
.. figure:: /_images/011/memdemo_00.*
|
.. figure:: /_images/011/memdemo_00.*
|
||||||
:class: width-helper
|
:class: width-helper
|
||||||
|
@ -693,10 +684,10 @@ Solving sequential SAT problems
|
||||||
|
|
||||||
The SAT solver functionality in Yosys can not only be used to solve
|
The SAT solver functionality in Yosys can not only be used to solve
|
||||||
combinatorial problems, but can also solve sequential problems. Let's consider
|
combinatorial problems, but can also solve sequential problems. Let's consider
|
||||||
the entire memdemo module from ``memdemo.v`` (:numref:`memdemo_v` above) and
|
the ``memdemo`` design from :ref:`advanced_logic_cones` again, and suppose we
|
||||||
suppose we want to know which sequence of input values for ``d`` will cause the
|
want to know which sequence of input values for ``d`` will cause the output y to
|
||||||
output y to produce the sequence 1, 2, 3 from any initial state. Let's use the
|
produce the sequence 1, 2, 3 from any initial state. Let's use the following
|
||||||
following command:
|
command:
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
.. code-block:: yoscrypt
|
||||||
|
|
||||||
|
|
|
@ -1,16 +1,11 @@
|
||||||
Selections
|
Selections
|
||||||
----------
|
----------
|
||||||
|
|
||||||
.. todo:: expand on text
|
.. role:: yoscrypt(code)
|
||||||
|
:language: yoscrypt
|
||||||
|
|
||||||
Most Yosys commands make use of the "selection framework" of Yosys. It can be
|
The selection framework
|
||||||
used to apply commands only to part of the design. For example:
|
~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
.. code:: yoscrypt
|
|
||||||
|
|
||||||
delete # will delete the whole design, but
|
|
||||||
|
|
||||||
delete foobar # will only delete the module foobar.
|
|
||||||
|
|
||||||
The :cmd:ref:`select` command can be used to create a selection for subsequent
|
The :cmd:ref:`select` command can be used to create a selection for subsequent
|
||||||
commands. For example:
|
commands. For example:
|
||||||
|
@ -19,11 +14,28 @@ commands. For example:
|
||||||
|
|
||||||
select foobar # select the module foobar
|
select foobar # select the module foobar
|
||||||
delete # delete selected objects
|
delete # delete selected objects
|
||||||
select -clear # reset selection (select whole design)
|
|
||||||
|
|
||||||
Many of the examples on this page make use of the :cmd:ref:`show` command to
|
Normally the :cmd:ref:`select` command overwrites a previous selection. The
|
||||||
visually demonstrate the effect of selections. For a more detailed look at this
|
commands :yoscrypt:`select -add` and :yoscrypt:`select -del` can be used to add
|
||||||
command, refer to :ref:`interactive_show`.
|
or remove objects from the current selection.
|
||||||
|
|
||||||
|
The command :yoscrypt:`select -clear` can be used to reset the selection to the
|
||||||
|
default, which is a complete selection of everything in the current module.
|
||||||
|
|
||||||
|
This selection framework can also be used directly in many other commands.
|
||||||
|
Whenever a command has ``[selection]`` as last argument in its usage help, this
|
||||||
|
means that it will use the engine behind the :cmd:ref:`select` command to
|
||||||
|
evaluate additional arguments and use the resulting selection instead of the
|
||||||
|
selection created by the last :cmd:ref:`select` command.
|
||||||
|
|
||||||
|
For example, the command :cmd:ref:`delete` will delete everything in the current
|
||||||
|
selection; while :yoscrypt:`delete foobar` will only delete the module foobar.
|
||||||
|
If no :cmd:ref:`select` command has been made, then the "current selection" will
|
||||||
|
be the whole design.
|
||||||
|
|
||||||
|
.. note:: Many of the examples on this page make use of the :cmd:ref:`show`
|
||||||
|
command to visually demonstrate the effect of selections. For a more
|
||||||
|
detailed look at this command, refer to :ref:`interactive_show`.
|
||||||
|
|
||||||
How to make a selection
|
How to make a selection
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -48,7 +60,7 @@ Commands can be executed in *module/* or *design/* context. Until now all
|
||||||
commands have been executed in design context. The :cmd:ref:`cd` command can be
|
commands have been executed in design context. The :cmd:ref:`cd` command can be
|
||||||
used to switch to module context.
|
used to switch to module context.
|
||||||
|
|
||||||
In module context all commands only effect the active module. Objects in the
|
In module context, all commands only effect the active module. Objects in the
|
||||||
module are selected without the ``<module_name>/`` prefix. For example:
|
module are selected without the ``<module_name>/`` prefix. For example:
|
||||||
|
|
||||||
.. code:: yoscrypt
|
.. code:: yoscrypt
|
||||||
|
@ -62,233 +74,102 @@ module are selected without the ``<module_name>/`` prefix. For example:
|
||||||
cd .. # switch back to design
|
cd .. # switch back to design
|
||||||
|
|
||||||
Note: Most synthesis scripts never switch to module context. But it is a very
|
Note: Most synthesis scripts never switch to module context. But it is a very
|
||||||
powerful tool for interactive design investigation.
|
powerful tool which we explore more in
|
||||||
|
:doc:`/using_yosys/more_scripting/interactive_investigation`.
|
||||||
|
|
||||||
Selecting by object property or type
|
Selecting by object property or type
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
Special patterns can be used to select by object property or type. For example:
|
Special patterns can be used to select by object property or type. For example:
|
||||||
|
|
||||||
.. code:: yoscrypt
|
- select all wires whose names start with ``reg_``: :yoscrypt:`select w:reg_*`
|
||||||
|
- select all objects with the attribute ``foobar`` set: :yoscrypt:`select a:foobar`
|
||||||
|
- select all objects with the attribute ``foobar`` set to 42: :yoscrypt:`select a:foobar=42`
|
||||||
|
- select all modules with the attribute ``blabla`` set: :yoscrypt:`select A:blabla`
|
||||||
|
- select all $add cells from the module foo: :yoscrypt:`select foo/t:$add`
|
||||||
|
|
||||||
select w:reg_* # select all wires whose names start with reg_
|
A complete list of pattern expressions can be found in :doc:`/cmd/select`.
|
||||||
select a:foobar # select all objects with the attribute foobar set
|
|
||||||
select a:foobar=42 # select all objects with the attribute foobar set to 42
|
|
||||||
select A:blabla # select all modules with the attribute blabla set
|
|
||||||
select foo/t:$add # select all $add cells from the module foo
|
|
||||||
|
|
||||||
A complete list of this pattern expressions can be found in the command
|
Operations on selections
|
||||||
reference to the :cmd:ref:`select` command.
|
~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Combining selections
|
Combining selections
|
||||||
^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
When more than one selection expression is used in one statement, then they are
|
The :cmd:ref:`select` command is actually much more powerful than it might seem
|
||||||
pushed on a stack. The final elements on the stack are combined into a union:
|
at first glance. When it is called with multiple arguments, each argument is
|
||||||
|
evaluated and pushed separately on a stack. After all arguments have been
|
||||||
|
processed it simply creates the union of all elements on the stack. So
|
||||||
|
:yoscrypt:`select t:$add a:foo` will select all ``$add`` cells and all objects
|
||||||
|
with the ``foo`` attribute set:
|
||||||
|
|
||||||
.. code:: yoscrypt
|
.. literalinclude:: /APPNOTE_011_Design_Investigation/foobaraddsub.v
|
||||||
|
:caption: Test module for operations on selections
|
||||||
|
:name: foobaraddsub
|
||||||
|
:language: verilog
|
||||||
|
|
||||||
select t:$dff r:WIDTH>1 # all cells of type $dff and/or with a parameter WIDTH > 1
|
.. code-block::
|
||||||
|
:caption: Output for command ``select t:$add a:foo -list`` on :numref:`foobaraddsub`
|
||||||
|
|
||||||
Special ``%``-commands can be used to combine the elements on the stack:
|
yosys> select t:$add a:foo -list
|
||||||
|
foobaraddsub/$add$foobaraddsub.v:6$3
|
||||||
|
foobaraddsub/$sub$foobaraddsub.v:5$2
|
||||||
|
foobaraddsub/$add$foobaraddsub.v:4$1
|
||||||
|
|
||||||
.. code:: yoscrypt
|
In many cases simply adding more and more stuff to the selection is an
|
||||||
|
ineffective way of selecting the interesting part of the design. Special
|
||||||
|
arguments can be used to combine the elements on the stack. For example the
|
||||||
|
``%i`` arguments pops the last two elements from the stack, intersects them, and
|
||||||
|
pushes the result back on the stack. So :yoscrypt:`select t:$add a:foo %i` will
|
||||||
|
select all ``$add`` cells that have the ``foo`` attribute set:
|
||||||
|
|
||||||
select t:$dff r:WIDTH>1 %i # all cells of type $dff *AND* with a parameter WIDTH > 1
|
.. code-block::
|
||||||
|
:caption: Output for command ``select t:$add a:foo %i -list`` on :numref:`foobaraddsub`
|
||||||
|
|
||||||
|
yosys> select t:$add a:foo %i -list
|
||||||
|
foobaraddsub/$add$foobaraddsub.v:4$1
|
||||||
|
|
||||||
Examples for ``%``-codes (see :doc:`/cmd/select` for full list):
|
Some of the special ``%``-codes:
|
||||||
|
|
||||||
- ``%u``: union of top two elements on stack -- pop 2, push 1
|
- ``%u``: union of top two elements on stack -- pop 2, push 1
|
||||||
- ``%d``: difference of top two elements on stack -- pop 2, push 1
|
- ``%d``: difference of top two elements on stack -- pop 2, push 1
|
||||||
- ``%i``: intersection of top two elements on stack -- pop 2, push 1
|
- ``%i``: intersection of top two elements on stack -- pop 2, push 1
|
||||||
- ``%n``: inverse of top element on stack -- pop 1, push 1
|
- ``%n``: inverse of top element on stack -- pop 1, push 1
|
||||||
|
|
||||||
|
See :doc:`/cmd/select` for the full list.
|
||||||
|
|
||||||
Expanding selections
|
Expanding selections
|
||||||
^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
Selections of cells and wires can be expanded along connections using
|
The listing in :numref:`sumprod` uses the Yosys non-standard ``{... *}`` syntax
|
||||||
``%``-codes for selecting input cones (``%ci``), output cones (``%co``), or
|
to set the attribute ``sumstuff`` on all cells generated by the first assign
|
||||||
both (``%x``).
|
statement. (This works on arbitrary large blocks of Verilog code an can be used
|
||||||
|
to mark portions of code for analysis.)
|
||||||
|
|
||||||
.. code:: yoscrypt
|
.. literalinclude:: /APPNOTE_011_Design_Investigation/sumprod.v
|
||||||
|
|
||||||
# select all wires that are inputs to $add cells
|
|
||||||
select t:$add %ci w:* %i
|
|
||||||
|
|
||||||
Additional constraints such as port names can be specified.
|
|
||||||
|
|
||||||
.. code:: yoscrypt
|
|
||||||
|
|
||||||
# select all wires that connect a "Q" output with a "D" input
|
|
||||||
select c:* %co:+[Q] w:* %i c:* %ci:+[D] w:* %i %i
|
|
||||||
|
|
||||||
# select the multiplexer tree that drives the signal 'state'
|
|
||||||
select state %ci*:+$mux,$pmux[A,B,Y]
|
|
||||||
|
|
||||||
See :doc:`/cmd/select` for full documentation of these expressions.
|
|
||||||
|
|
||||||
Incremental selection
|
|
||||||
^^^^^^^^^^^^^^^^^^^^^
|
|
||||||
|
|
||||||
Sometimes a selection can most easily be described by a series of add/delete
|
|
||||||
operations. The commands ``select -add`` and ``select -del`` respectively add or
|
|
||||||
remove objects from the current selection instead of overwriting it.
|
|
||||||
|
|
||||||
.. code:: yoscrypt
|
|
||||||
|
|
||||||
select -none # start with an empty selection
|
|
||||||
select -add reg_* # select a bunch of objects
|
|
||||||
select -del reg_42 # but not this one
|
|
||||||
select -add state %ci # and add more stuff
|
|
||||||
|
|
||||||
Within a select expression the token ``%`` can be used to push the previous selection
|
|
||||||
on the stack.
|
|
||||||
|
|
||||||
.. code:: yoscrypt
|
|
||||||
|
|
||||||
select t:$add t:$sub # select all $add and $sub cells
|
|
||||||
select % %ci % %d # select only the input wires to those cells
|
|
||||||
|
|
||||||
Creating selection variables
|
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
||||||
|
|
||||||
Selections can be stored under a name with the ``select -set <name>``
|
|
||||||
command. The stored selections can be used in later select expressions
|
|
||||||
using the syntax ``@<name>``.
|
|
||||||
|
|
||||||
.. code:: yoscrypt
|
|
||||||
|
|
||||||
select -set cone_a state_a %ci*:-$dff # set @cone_a to the input cone of state_a
|
|
||||||
select -set cone_b state_b %ci*:-$dff # set @cone_b to the input cone of state_b
|
|
||||||
select @cone_a @cone_b %i # select the objects that are in both cones
|
|
||||||
|
|
||||||
Remember that select expressions can also be used directly as arguments to most
|
|
||||||
commands. Some commands also except a single select argument to some options.
|
|
||||||
In those cases selection variables must be used to capture more complex selections.
|
|
||||||
|
|
||||||
.. code:: yoscrypt
|
|
||||||
|
|
||||||
dump @cone_a @cone_b
|
|
||||||
|
|
||||||
select -set cone_ab @cone_a @cone_b %i
|
|
||||||
show -color red @cone_ab -color magenta @cone_a -color blue @cone_b
|
|
||||||
|
|
||||||
Example:
|
|
||||||
|
|
||||||
.. literalinclude:: ../../../resources/PRESENTATION_ExAdv/select.v
|
|
||||||
:language: verilog
|
|
||||||
:caption: ``docs/resources/PRESENTATION_ExAdv/select.v``
|
|
||||||
|
|
||||||
.. literalinclude:: ../../../resources/PRESENTATION_ExAdv/select.ys
|
|
||||||
:language: yoscrypt
|
|
||||||
:caption: ``docs/resources/PRESENTATION_ExAdv/select.ys``
|
|
||||||
|
|
||||||
.. figure:: /_images/res/PRESENTATION_ExAdv/select.*
|
|
||||||
:class: width-helper
|
|
||||||
|
|
||||||
.. todo:: combine below sections into above where possible
|
|
||||||
|
|
||||||
Working with selections
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
.. figure:: /_images/011/example_03.*
|
|
||||||
:class: width-helper
|
|
||||||
:name: seladd
|
|
||||||
|
|
||||||
Output of :cmd:ref:`show` after ``select $2`` or ``select t:$add`` (see also
|
|
||||||
:numref:`example_out`)
|
|
||||||
|
|
||||||
But for most interactive work we want to further narrow the set of selected
|
|
||||||
objects. This can be done using the :cmd:ref:`select` command.
|
|
||||||
|
|
||||||
For example, if the command ``select $2`` is executed, a subsequent
|
|
||||||
:cmd:ref:`show` command will yield the diagram shown in :numref:`seladd`. Note
|
|
||||||
that the nets are now displayed in ellipses. This indicates that they are not
|
|
||||||
selected, but only shown because the diagram contains a cell that is connected
|
|
||||||
to the net. This of course makes no difference for the circuit that is shown,
|
|
||||||
but it can be a useful information when manipulating selections.
|
|
||||||
|
|
||||||
Objects can not only be selected by their name but also by other properties. For
|
|
||||||
example ``select t:$add`` will select all cells of type ``$add``. In this case
|
|
||||||
this is also yields the diagram shown in :numref:`seladd`.
|
|
||||||
|
|
||||||
.. literalinclude:: ../APPNOTE_011_Design_Investigation/foobaraddsub.v
|
|
||||||
:caption: Test module for operations on selections
|
|
||||||
:name: foobaraddsub
|
|
||||||
:language: verilog
|
|
||||||
|
|
||||||
The output of ``help select`` contains a complete syntax reference for
|
|
||||||
matching different properties.
|
|
||||||
|
|
||||||
Many commands can operate on explicit selections. For example the command ``dump
|
|
||||||
t:$add`` will print information on all ``$add`` cells in the active module.
|
|
||||||
Whenever a command has ``[selection]`` as last argument in its usage help, this
|
|
||||||
means that it will use the engine behind the :cmd:ref:`select` command to
|
|
||||||
evaluate additional arguments and use the resulting selection instead of the
|
|
||||||
selection created by the last :cmd:ref:`select` command.
|
|
||||||
|
|
||||||
Normally the :cmd:ref:`select` command overwrites a previous selection. The
|
|
||||||
commands ``select -add`` and ``select -del`` can be used to add or remove
|
|
||||||
objects from the current selection.
|
|
||||||
|
|
||||||
The command ``select -clear`` can be used to reset the selection to the default,
|
|
||||||
which is a complete selection of everything in the current module.
|
|
||||||
|
|
||||||
Operations on selections
|
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
|
|
||||||
.. literalinclude:: ../APPNOTE_011_Design_Investigation/sumprod.v
|
|
||||||
:caption: Another test module for operations on selections
|
:caption: Another test module for operations on selections
|
||||||
:name: sumprod
|
:name: sumprod
|
||||||
:language: verilog
|
:language: verilog
|
||||||
|
|
||||||
|
Selecting ``a:sumstuff`` in this module will yield the following circuit
|
||||||
|
diagram:
|
||||||
|
|
||||||
.. figure:: /_images/011/sumprod_00.*
|
.. figure:: /_images/011/sumprod_00.*
|
||||||
:class: width-helper
|
:class: width-helper
|
||||||
:name: sumprod_00
|
:name: sumprod_00
|
||||||
|
|
||||||
Output of ``show a:sumstuff`` on :numref:`sumprod`
|
Output of ``show a:sumstuff`` on :numref:`sumprod`
|
||||||
|
|
||||||
The :cmd:ref:`select` command is actually much more powerful than it might seem
|
As only the cells themselves are selected, but not the temporary wire ``$1_Y``,
|
||||||
on the first glimpse. When it is called with multiple arguments, each argument
|
the two adders are shown as two disjunct parts. This can be very useful for
|
||||||
is evaluated and pushed separately on a stack. After all arguments have been
|
global signals like clock and reset signals: just unselect them using a command
|
||||||
processed it simply creates the union of all elements on the stack. So the
|
such as :yoscrypt:`select -del clk rst` and each cell using them will get its
|
||||||
following command will select all ``$add`` cells and all objects with the
|
own net label.
|
||||||
``foo`` attribute set:
|
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
|
||||||
|
|
||||||
select t:$add a:foo
|
|
||||||
|
|
||||||
(Try this with the design shown in :numref:`foobaraddsub`. Use the ``select
|
|
||||||
-list`` command to list the current selection.)
|
|
||||||
|
|
||||||
In many cases simply adding more and more stuff to the selection is an
|
|
||||||
ineffective way of selecting the interesting part of the design. Special
|
|
||||||
arguments can be used to combine the elements on the stack. For example
|
|
||||||
the ``%i`` arguments pops the last two elements from the stack, intersects
|
|
||||||
them, and pushes the result back on the stack. So the following command
|
|
||||||
will select all ``$add ``cells that have the ``foo`` attribute set:
|
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
|
||||||
|
|
||||||
select t:$add a:foo %i
|
|
||||||
|
|
||||||
The listing in :numref:`sumprod` uses the Yosys non-standard ``{... *}`` syntax
|
|
||||||
to set the attribute ``sumstuff`` on all cells generated by the first assign
|
|
||||||
statement. (This works on arbitrary large blocks of Verilog code an can be used
|
|
||||||
to mark portions of code for analysis.)
|
|
||||||
|
|
||||||
Selecting ``a:sumstuff`` in this module will yield the circuit diagram shown in
|
|
||||||
:numref:`sumprod_00`. As only the cells themselves are selected, but not the
|
|
||||||
temporary wire ``$1_Y``, the two adders are shown as two disjunct parts. This
|
|
||||||
can be very useful for global signals like clock and reset signals: just
|
|
||||||
unselect them using a command such as ``select -del clk rst`` and each cell
|
|
||||||
using them will get its own net label.
|
|
||||||
|
|
||||||
In this case however we would like to see the cells connected properly. This can
|
In this case however we would like to see the cells connected properly. This can
|
||||||
be achieved using the ``%x`` action, that broadens the selection, i.e. for each
|
be achieved using the ``%x`` action, that broadens the selection, i.e. for each
|
||||||
selected wire it selects all cells connected to the wire and vice versa. So
|
selected wire it selects all cells connected to the wire and vice versa. So
|
||||||
``show a:sumstuff %x`` yields the diagram shown in :numref:`sumprod_01`.
|
:yoscrypt:`show a:sumstuff %x` yields the diagram shown in :numref:`sumprod_01`:
|
||||||
|
|
||||||
.. figure:: /_images/011/sumprod_01.*
|
.. figure:: /_images/011/sumprod_01.*
|
||||||
:class: width-helper
|
:class: width-helper
|
||||||
|
@ -297,27 +178,39 @@ selected wire it selects all cells connected to the wire and vice versa. So
|
||||||
Output of ``show a:sumstuff %x`` on :numref:`sumprod`
|
Output of ``show a:sumstuff %x`` on :numref:`sumprod`
|
||||||
|
|
||||||
Selecting logic cones
|
Selecting logic cones
|
||||||
~~~~~~~~~~~~~~~~~~~~~
|
^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
:numref:`sumprod_01` shows what is called the ``input cone`` of ``sum``, i.e.
|
:numref:`sumprod_01` shows what is called the ``input cone`` of ``sum``, i.e.
|
||||||
all cells and signals that are used to generate the signal ``sum``. The ``%ci``
|
all cells and signals that are used to generate the signal ``sum``. The ``%ci``
|
||||||
action can be used to select the input cones of all object in the top selection
|
action can be used to select the input cones of all object in the top selection
|
||||||
in the stack maintained by the :cmd:ref:`select` command.
|
in the stack maintained by the :cmd:ref:`select` command.
|
||||||
|
|
||||||
As the ``%x`` action, this commands broadens the selection by one "step".
|
As with the ``%x`` action, this commands broadens the selection by one "step".
|
||||||
But this time the operation only works against the direction of data
|
But this time the operation only works against the direction of data flow. That
|
||||||
flow. That means, wires only select cells via output ports and cells
|
means, wires only select cells via output ports and cells only select wires via
|
||||||
only select wires via input ports.
|
input ports.
|
||||||
|
|
||||||
:numref:`select_prod` show the sequence of diagrams generated by the following
|
The following sequence of diagrams demonstrates this step-wise expansion:
|
||||||
commands:
|
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
.. figure:: /_images/011/sumprod_02.*
|
||||||
|
:class: width-helper
|
||||||
|
|
||||||
show prod
|
Output of ``show prod`` on :numref:`sumprod`
|
||||||
show prod %ci
|
|
||||||
show prod %ci %ci
|
.. figure:: /_images/011/sumprod_03.*
|
||||||
show prod %ci %ci %ci
|
:class: width-helper
|
||||||
|
|
||||||
|
Output of ``show prod %ci`` on :numref:`sumprod`
|
||||||
|
|
||||||
|
.. figure:: /_images/011/sumprod_04.*
|
||||||
|
:class: width-helper
|
||||||
|
|
||||||
|
Output of ``show prod %ci %ci`` on :numref:`sumprod`
|
||||||
|
|
||||||
|
.. figure:: /_images/011/sumprod_05.*
|
||||||
|
:class: width-helper
|
||||||
|
|
||||||
|
Output of ``show prod %ci %ci %ci`` on :numref:`sumprod`
|
||||||
|
|
||||||
When selecting many levels of logic, repeating ``%ci`` over and over again can
|
When selecting many levels of logic, repeating ``%ci`` over and over again can
|
||||||
be a bit dull. So there is a shortcut for that: the number of iterations can be
|
be a bit dull. So there is a shortcut for that: the number of iterations can be
|
||||||
|
@ -327,28 +220,28 @@ performing the ``%ci`` action three times.
|
||||||
The action ``%ci*`` performs the ``%ci`` action over and over again until it
|
The action ``%ci*`` performs the ``%ci`` action over and over again until it
|
||||||
has no effect anymore.
|
has no effect anymore.
|
||||||
|
|
||||||
.. figure:: /_images/011/select_prod.*
|
.. _advanced_logic_cones:
|
||||||
:class: width-helper
|
|
||||||
:name: select_prod
|
Advanced logic cone selection
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
Objects selected by ``select prod %ci...``
|
|
||||||
|
|
||||||
In most cases there are certain cell types and/or ports that should not be
|
In most cases there are certain cell types and/or ports that should not be
|
||||||
considered for the ``%ci`` action, or we only want to follow certain cell types
|
considered for the ``%ci`` action, or we only want to follow certain cell types
|
||||||
and/or ports. This can be achieved using additional patterns that can be
|
and/or ports. This can be achieved using additional patterns that can be
|
||||||
appended to the ``%ci`` action.
|
appended to the ``%ci`` action.
|
||||||
|
|
||||||
Lets consider the design from :numref:`memdemo_src`. It serves no purpose other
|
Lets consider :numref:`memdemo_src`. It serves no purpose other than being a
|
||||||
than being a non-trivial circuit for demonstrating some of the advanced Yosys
|
non-trivial circuit for demonstrating some of the advanced Yosys features.
|
||||||
features. We synthesize the circuit using ``proc; opt; memory; opt`` and change
|
|
||||||
to the ``memdemo`` module with ``cd memdemo``. If we type :cmd:ref:`show` now we
|
|
||||||
see the diagram shown in :numref:`memdemo_00`.
|
|
||||||
|
|
||||||
.. literalinclude:: ../APPNOTE_011_Design_Investigation/memdemo.v
|
.. literalinclude:: /APPNOTE_011_Design_Investigation/memdemo.v
|
||||||
:caption: Demo circuit for demonstrating some advanced Yosys features
|
:caption: Demo circuit for demonstrating some advanced Yosys features
|
||||||
:name: memdemo_src
|
:name: memdemo_src
|
||||||
:language: verilog
|
:language: verilog
|
||||||
|
|
||||||
|
We synthesize the circuit using ``proc; opt; memory; opt`` and change to the
|
||||||
|
``memdemo`` module with ``cd memdemo``. If we type :cmd:ref:`show` now we see
|
||||||
|
the diagram shown in :numref:`memdemo_00`.
|
||||||
|
|
||||||
.. figure:: /_images/011/memdemo_00.*
|
.. figure:: /_images/011/memdemo_00.*
|
||||||
:class: width-helper
|
:class: width-helper
|
||||||
:name: memdemo_00
|
:name: memdemo_00
|
||||||
|
@ -377,12 +270,12 @@ cells:
|
||||||
show y %ci2:+$dff[Q,D]
|
show y %ci2:+$dff[Q,D]
|
||||||
|
|
||||||
To add a pattern we add a colon followed by the pattern to the ``%ci`` action.
|
To add a pattern we add a colon followed by the pattern to the ``%ci`` action.
|
||||||
The pattern it self starts with ``-`` or ``+``, indicating if it is an include
|
The pattern itself starts with ``-`` or ``+``, indicating if it is an include or
|
||||||
or exclude pattern, followed by an optional comma separated list of cell types,
|
exclude pattern, followed by an optional comma separated list of cell types,
|
||||||
followed by an optional comma separated list of port names in square brackets.
|
followed by an optional comma separated list of port names in square brackets.
|
||||||
|
|
||||||
Since we know that the only cell considered in this case is a ``$dff`` cell,
|
Since we know that the only cell considered in this case is a ``$dff`` cell, we
|
||||||
we could as well only specify the port names:
|
could as well only specify the port names:
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
.. code-block:: yoscrypt
|
||||||
|
|
||||||
|
@ -400,16 +293,16 @@ Or we could decide to tell the ``%ci`` action to not follow the ``CLK`` input:
|
||||||
|
|
||||||
Output of ``show y %ci2:+$dff[Q,D] %ci*:-$mux[S]:-$dff``
|
Output of ``show y %ci2:+$dff[Q,D] %ci*:-$mux[S]:-$dff``
|
||||||
|
|
||||||
Next we would investigate the next logic level by adding another ``%ci2`` to
|
Next we would investigate the next logic level by adding another ``%ci2`` to the
|
||||||
the command:
|
command:
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
.. code-block:: yoscrypt
|
||||||
|
|
||||||
show y %ci2:-[CLK] %ci2
|
show y %ci2:-[CLK] %ci2
|
||||||
|
|
||||||
From this we would learn that the next cell is a ``$mux`` cell and we would
|
From this we would learn that the next cell is a ``$mux`` cell and we would add
|
||||||
add additional pattern to narrow the selection on the path we are
|
additional pattern to narrow the selection on the path we are interested. In the
|
||||||
interested. In the end we would end up with a command such as
|
end we would end up with a command such as
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
.. code-block:: yoscrypt
|
||||||
|
|
||||||
|
@ -429,7 +322,30 @@ boolean operations such as intersection (``%i``) and difference (``%d``) are
|
||||||
powerful tools for extracting the relevant portions of the circuit under
|
powerful tools for extracting the relevant portions of the circuit under
|
||||||
investigation.
|
investigation.
|
||||||
|
|
||||||
See ``help select`` for a complete list of actions available in selections.
|
Again, see :doc:`/cmd/select` for full documentation of these expressions.
|
||||||
|
|
||||||
|
Incremental selection
|
||||||
|
^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
Sometimes a selection can most easily be described by a series of add/delete
|
||||||
|
operations. As mentioned previously, the commands :yoscrypt:`select -add` and
|
||||||
|
:yoscrypt:`select -del` respectively add or remove objects from the current
|
||||||
|
selection instead of overwriting it.
|
||||||
|
|
||||||
|
.. code:: yoscrypt
|
||||||
|
|
||||||
|
select -none # start with an empty selection
|
||||||
|
select -add reg_* # select a bunch of objects
|
||||||
|
select -del reg_42 # but not this one
|
||||||
|
select -add state %ci # and add more stuff
|
||||||
|
|
||||||
|
Within a select expression the token ``%`` can be used to push the previous selection
|
||||||
|
on the stack.
|
||||||
|
|
||||||
|
.. code:: yoscrypt
|
||||||
|
|
||||||
|
select t:$add t:$sub # select all $add and $sub cells
|
||||||
|
select % %ci % %d # select only the input wires to those cells
|
||||||
|
|
||||||
Storing and recalling selections
|
Storing and recalling selections
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -437,19 +353,33 @@ Storing and recalling selections
|
||||||
The current selection can be stored in memory with the command ``select -set
|
The current selection can be stored in memory with the command ``select -set
|
||||||
<name>``. It can later be recalled using ``select @<name>``. In fact, the
|
<name>``. It can later be recalled using ``select @<name>``. In fact, the
|
||||||
``@<name>`` expression pushes the stored selection on the stack maintained by
|
``@<name>`` expression pushes the stored selection on the stack maintained by
|
||||||
the :cmd:ref:`select` command. So for example
|
the :cmd:ref:`select` command. So for example :yoscrypt:`select @foo @bar %i`
|
||||||
|
|
||||||
.. code-block:: yoscrypt
|
|
||||||
|
|
||||||
select @foo @bar %i
|
|
||||||
|
|
||||||
will select the intersection between the stored selections ``foo`` and ``bar``.
|
will select the intersection between the stored selections ``foo`` and ``bar``.
|
||||||
|
|
||||||
In larger investigation efforts it is highly recommended to maintain a
|
In larger investigation efforts it is highly recommended to maintain a script
|
||||||
script that sets up relevant selections, so they can easily be recalled,
|
that sets up relevant selections, so they can easily be recalled, for example
|
||||||
for example when Yosys needs to be re-run after a design or source code
|
when Yosys needs to be re-run after a design or source code change.
|
||||||
change.
|
|
||||||
|
|
||||||
The :cmd:ref:`history` command can be used to list all recent interactive
|
The :cmd:ref:`history` command can be used to list all recent interactive
|
||||||
commands. This feature can be useful for creating such a script from the
|
commands. This feature can be useful for creating such a script from the
|
||||||
commands used in an interactive session.
|
commands used in an interactive session.
|
||||||
|
|
||||||
|
Remember that select expressions can also be used directly as arguments to most
|
||||||
|
commands. Some commands also accept a single select argument to some options. In
|
||||||
|
those cases selection variables must be used to capture more complex selections.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
.. literalinclude:: ../../../resources/PRESENTATION_ExAdv/select.v
|
||||||
|
:language: verilog
|
||||||
|
:caption: ``docs/resources/PRESENTATION_ExAdv/select.v``
|
||||||
|
|
||||||
|
.. literalinclude:: ../../../resources/PRESENTATION_ExAdv/select.ys
|
||||||
|
:language: yoscrypt
|
||||||
|
:caption: ``docs/resources/PRESENTATION_ExAdv/select.ys``
|
||||||
|
:name: select_ys
|
||||||
|
|
||||||
|
.. figure:: /_images/res/PRESENTATION_ExAdv/select.*
|
||||||
|
:class: width-helper
|
||||||
|
|
||||||
|
Circuit diagram produced by :numref:`select_ys`
|
||||||
|
|
Loading…
Reference in a new issue