Counter test
~~~~~~~~~~~~
This example design features a simple 4-bit counter driving LEDs. To build the
counter example, depending on your hardware, run:
.. code-block:: bash
:name: example-counter-a35t-group
TARGET="arty_35" make -C counter_test
.. code-block:: bash
:name: example-counter-a100t-group
TARGET="arty_100" make -C counter_test
.. code-block:: bash
:name: example-counter-basys3-group
TARGET="basys3" make -C counter_test
.. code-block:: bash
:name: example-counter-zybo-group
TARGET="zybo" make -C counter_test
Now, for **Arty and Basys3**, you can upload the design with:
.. code-block:: bash
openocd -f ${INSTALL_DIR}/conda/share/openocd/scripts/board/digilent_arty.cfg -c "init; pld load 0 top.bit; exit"
The result should be as follows:
.. image:: ../../docs/images/counter-example-arty.gif
:align: center
:width: 50%
For **Zybo**, please follow the `guide on how to load a bitstream from U-boot <https://symbiflow-examples.readthedocs.io/en/latest/running-examples.html#load-bitstream-from-u-boot>`_.
Once the bitstream is loaded, the result should be as follows:
.. image:: ../../docs/images/counter-example-zyboz7.gif
:align: center
:width: 50%
On the picocom terminal, you can control the counter behaviour to stop it, or let it count backwards, by toggling values of the EMIO pins of the ARM Processing System (PS).
You can control the counter enable signal with:
.. code-block:: bash
gpio set 54
gpio clear 54
If GPIO 54 is set, the counter is disabled. It is enabled if the GPIO 54 is cleared. The result should be as follows:
.. image:: ../../docs/images/counter-example-zyboz7-clken.gif
:align: center
:width: 50%
You can control the counter direction with:
.. code-block:: bash
gpio set 55
gpio clear 55
If GPIO 55 is set, the counter goes backwards. It goes forwared if the GPIO 54 is cleared. The result should be as follows:
.. image:: ../../docs/images/counter-example-zyboz7-reverse.gif
:align: center
:width: 50%