Skip to content

fpgaperf

Ryan Johnson edited this page Jul 28, 2020 · 4 revisions

fpgaperf.py

fpgaperf.py takes a project, a board, and a toolchain as arguments, and uses the specified toolchain the generate a bitstream for the specified project. At the end of the bitstream generation, it prints the stats of the run, including runtimes, clock information, and resource utilization.

Below is an example output of the blinky project, using the vivado toolchain and the arty board:

$ python3 fpgaperf.py --toolchain vivado --project blinky --board arty
Writing to build/blinky_vivado_xc7_a35tcsg324-1_arty_xdc_carry-n

===============================
Setting
===============================

+-----------+-------------------------------------------------+
| Settings  | Value                                           |
+-----------+-------------------------------------------------+
| Design    | blinky_vivado_xc7_a35tcsg324-1_arty_xdc_carry-n |
| Family    | xc7                                             |
| Device    | a35t                                            |
| Package   | csg324-1                                        |
| Project   | blinky                                          |
| Toolchain | vivado                                          |
| Strategy  | None                                            |
| Carry     | False                                           |
| Seed      | default                                         |
+-----------+-------------------------------------------------+

===============================
Clocks
===============================

+--------------+-------------+----------------+------+-----------------+----------------+
| Clock domain | Actual freq | Requested freq | Met? | Setup violation | Hold violation |
+--------------+-------------+----------------+------+-----------------+----------------+
| clk_i        | 481.696 MHz | 100.000 MHz    | True | 0.000 ns        | 0.000 ns       |
+--------------+-------------+----------------+------+-----------------+----------------+

===============================
Toolchain Run-Times
===============================

+--------------+--------------------+
| Stage        | Run Time (seconds) |
+--------------+--------------------+
| prepare      | 1.373              |
| synthesis    | 41.000             |
| optimization | 22.000             |
| packing      | N/A                |
| placement    | N/A                |
| routing      | 31.000             |
| fasm         | N/A                |
| checkpoint   | N/A                |
| bitstream    | 24.000             |
| reports      | N/A                |
| total        | 327.179            |
| nop          | 0.030              |
| fasm2bels    | N/A                |
+--------------+--------------------+

===============================
FPGA resource utilization
===============================

+----------+------+
| Resource | Used |
+----------+------+
| BRAM     | 0    |
| CARRY    | 6    |
| DFF      | 32   |
| GLB      | N/A  |
| IOB      | 13   |
| LUT      | 20   |
| PLL      | 0    |
+----------+------+

So, running fpgaperf.py is pretty simple, but there are a few arguments you can give it to change things about the run.


Basic Arguments

--board - Which board will be used

--toolchain - Which toolchain will be used

--project - Which project will be built

Ex:

python3 fpgaperf.py --project oneblink --board basys3 --toolchain vpr

Extra Arguments

These arguments enhance/modify the normal run.

--verbose - Turns on a logger that prints messages during the run to help with debugging.

--overwrite -

--params_file -

--params_string -

--strategy -

--carry -

--no-carry -

--seed - Specifies a seed for the random factors of the run for vpr. If you want a better picture of a project's runtime and stats, you could try running the same project multiple times with different seeds and take the averages. However, --seed does not work with every toolchain. (see --list-seedable)


Other Arguments

These are arguments you can use to do something other than the normal run, and each is pretty straightforward:

--check-env - Iterates through each toolchain and checks the environment to see if the toolchain is correctly installed and ready to run. To check just one, specify the toolchain with the --toolchain argument.

--list-toolchains - Lists all toolchains.

--list-projects - Lists all projects in the projects directory.

--list-seedable - Lists the toolchains that are compatible with --seed.

Ex:

python3 fpgaperf.py --check-env --toolchain vivado-yosys
python3 fpgaperf.py --list-toolchains
python3 fpgaperf.py --list-projects
python3 fpgaperf.py --list-seedable

Directory Arguments

--out-prefix - This argument changes the folder to which you save the build details. The default is the build directory. But if you put --out-prefix other, then it will save the project files to the other directory. This looks like a great way to split up project runs into organized categories.

--out-dir - Instead of changing just the folder to place the directory in, this argument becomes the entire path from the fpga-tool-perf directory. However, if you want your directory inside another directory and the outside directory has not been created, you must use both --out-prefix and --out-dir.

Ex:

python3 fpgaperf.py --toolchain vivado --project oneblink --board basys3 --out-dir practice_build/firstrun --out-prefix practice_build

The above command will build your project to /fpga-tool-perf/practice_build/firstrun.

This can be helpful for personal organization of builds.

The projects are usually built within the build directory and the name of the folder within build is generated by all the settings of the run and ends up being very long. However, these settings are easily accessed, so it might be better to name the folders with shorter titles using the --out-dir, for easier navigating.


Build Arguments

The two commands below allow you to keep multiple copies of the same build and compare them to one another. This is especially helpful if you were to update one of the symbiflow tools and could then compare your old build to a new build under a different name.

--build_type - gives the project a name

--build - gives the project a number (really just another name).

Ex:

python3 fpgaperf.py --toolchain vivado --project oneblink --board basys3 --build_type justforfun --build 2

saves the directory under the name:

oneblink_vivado_xc7_a35tcpg236-1_basys3_justforfun_2_xdc_carry-n

To add a new project to the project directory, follow the instructions on the NewProjectInsertion wiki page.

Clone this wiki locally