Simulation

Chisel test simulation

FastVDMA can be simulated as a whole but certain components can be tested separately.

You can simulate the full memory to memory design by running:

make testM2M

The full stream to memory test by:

make testS2M

To run both full tests:

make test

To run all tests, including all mentioned above, execute:

make testall

Each test run generates a .vcd file which can be opened using GTKWave or any other .vcd viewer.

Output files are located in a separate sub directories inside the test_run_dir directory.

The full test should generate an outM2M.png/outS2M.png file demonstrating a 2D transfer with configurable stride. The resulting image should look similar to:

Reference image

Renode-Verilator co-simulation

FastVDMA provided script for the open source software development framework - Renode.

With the use of renode-verilator-integration, Renode runs Verilator simulation of the FastVDMA design and simulates the rest of the environment itself. This includes booting the Linux kernel. You may read more about the Renode’s co-simulation feature from this blog note.

Then, loading the FastVDMA driver it performs a demo image transfer, similar to the one from chisel test. FastVDMA provides the source code to the example driver that uses FastVDMA driver through DMAEngine as well as the demo user-space application.


Last update: 2024-07-01