3
0
Fork 0
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:
Krystine Sherwin 2023-10-11 12:46:26 +13:00
parent c61ab7d627
commit 8335044c35
No known key found for this signature in database
2 changed files with 177 additions and 256 deletions

View file

@ -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

View file

@ -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`