2019-09-01 23:15:53 -05:00
.. _run_fpga_task:
OpenFPGA Task
---------------
Tasks provide a framework for running the :ref: `run_fpga_flow` on
2019-09-02 03:45:05 -05:00
multiple benchmarks, architectures, and set of OpenFPGA parameters.
2019-09-01 23:15:53 -05:00
The structure of the framework is very similar to
`VTR-Tasks <https://docs.verilogtorouting.org/en/latest/vtr/tasks/> `_
2019-09-02 03:45:05 -05:00
implementation with additional functionality and minor file extension changes.
2019-09-01 23:15:53 -05:00
Task Directory
~~~~~~~~~~~~~~
2019-09-02 03:45:05 -05:00
The tasks are stored in a `` TASK_DIRECTORY `` , which by default points to
2019-09-01 23:15:53 -05:00
`` ${OPENFPGA_PATH}/openfpga_flow/tasks `` . Every directory or sub-directory in
2019-09-02 03:45:05 -05:00
task directory consisting of `` ../config/task.conf `` file can be referred to as a
2019-09-01 23:15:53 -05:00
task.
To create as task name called `` basic_flow `` following directory has to exist::
${TASK_DIRECTORY}/basic_flow/conf/task.conf
Similarly `` regression/regression_quick `` expect following structure::
${TASK_DIRECTORY}/regression/regression_quick/conf/task.conf
Running OpenFPGA Task:
~~~~~~~~~~~~~~~~~~~~~~
At a minimum `` open_fpga_flow.py `` requires following command-line arguments::
2019-09-02 03:45:05 -05:00
open_fpga_flow.py <task1_name> <task2_name> ... [<options> ]
2019-09-01 23:15:53 -05:00
where:
* `` <task_name> `` is the name of the task to run
2019-09-02 03:45:05 -05:00
* `` <options> `` Other command line arguments described below
2019-09-01 23:15:53 -05:00
2019-09-02 03:45:05 -05:00
Command-line Options
~~~~~~~~~~~~~~~~~~~~
2019-09-01 23:15:53 -05:00
2019-09-02 03:45:05 -05:00
.. option :: --maxthreads <number_of_threads>
2019-09-01 23:15:53 -05:00
2019-09-02 03:45:05 -05:00
This option defines the number of threads to run while executing task.
Each combination of architecture, benchmark and set of OpenFPGA Flow options
runs in a individual thread.
2019-09-01 23:15:53 -05:00
2019-09-02 03:45:05 -05:00
.. option :: --skip_thread_logs
Passsing this option skips printing logs from each OpenFPGA Flow script run.
.. option :: --exit_on_fail
Passsing this option exits the OpenFPGA task script with returncode 1,
if any threads fail to execute successfully. It is mainly used to while
performing regression test.
.. option :: --test_run
This option allows to debug OpenFPGA Task script
by skiping actual execution of OpenFPGA flow .
Passing this option prints the list of
commnad generated to execute using OpenFPGA flow.
.. option :: --debug
To enable detailed log printing.
Creating a new OpenFPGA Task
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
- Create the folder `` ${TASK_DIRECTORY}/<task_name> ``
- Create a file `` ${TASK_DIRECTORY}/<task_name>/config/task.conf `` in it
- Configure the task as explained in :ref: `Configuring a new OpenFPGA Task`
Configuring a new OpenFPGA Task
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2019-09-01 23:15:53 -05:00
The task configuration file `` task.conf `` consists of `` GENERAL `` ,
`` ARCHITECTURES `` , `` BENCHMARKS `` , `` SYNTHESIS_PARAM `` and
`` SCRIPT_PARAM_<var_name> `` sections.
Declaring all the above sections are mandatory.
.. note ::
2019-09-02 03:45:05 -05:00
The configuration file supports all the OpenFPGA Variables refer
:ref: `openfpga-variables` section to know more. Variable in the configuration
file is declared as `` ${PATH:<variable_name>} ``
2019-09-01 23:15:53 -05:00
General Section
^^^^^^^^^^^^^^^
2022-01-14 05:14:48 -06:00
.. option :: fpga_flow=<yosys_vpr|vpr_blif|yosys>
2019-09-01 23:15:53 -05:00
2019-09-02 03:45:05 -05:00
This option defines which OpenFPGA flow to run. By default `` yosys_vpr `` is executed.
2019-09-01 23:15:53 -05:00
.. option :: power_analysis=<true|false>
Specifies whether to perform power analysis or not.
.. option :: power_tech_file=<path_to_tech_XML_file>
2019-09-02 03:45:05 -05:00
Declares which tech XML file to use while performing Power Analysis.
2019-09-01 23:15:53 -05:00
.. option :: spice_output=<true|false>
Setting up this variable generates Spice Netlist at the end of the flow.
Equivalent of passing `` --vpr_fpga_spice `` command to :ref: `run_fpga_flow`
.. option :: verilog_output=<true|false>
Setting up this variable generates Verilog Netlist at the end of the flow.
Equivalent of passing `` --vpr_fpga_spice `` command to :ref: `run_fpga_flow`
.. option :: timeout_each_job=<true|false>
2021-10-29 08:34:27 -05:00
Specifies the timeout for each :ref: `run_fpga_flow` execution. Default is set to `` 20 min. ``
.. option :: verific=<true|false>
Specifies to use Verific as a frontend for Yosys while running a yosys_vpr flow.
The following standards are used by default for reading input HDL files:
* Verilog - `` vlog95 ``
* System Verilog - `` sv2012 ``
* VHDL - `` vhdl2008 ``
The option should be used only with custom Yosys template containing Verific commands.
OpenFPGA_SHELL Sections
^^^^^^^^^^^^^^^^^^^^^^^
User can specify OpenFPGA_SHELL options in this section.
.. option :: verific_include_dir=<include_dir>
The `` include_dir `` is path to the Verilog/VHDL include directory. If there are multiple paths then they can be
provided as a comma separated list.
.. option :: verific_library_dir=<library_dir>
The `` library_dir `` is path to the Verilog/VHDL library directory. Verific will search in this directory to
find undefined modules. If there are multiple paths then they can be provided as a comma separated list.
.. option :: verific_verilog_standard=<-vlog95|-vlog2k>
The option specifies Verilog language standard to be used while reading the Verilog files.
.. option :: verific_systemverilog_standard=<-sv2005|-sv2009|-sv2012>
The option specifies SystemVerilog language standard to be used while reading the SystemVerilog files.
.. option :: verific_vhdl_standard=<-vhdl87|-vhdl93|-vhdl2k|-vhdl2008>
The option specifies VHDL language standard to be used while reading the VHDL files.
2022-01-17 03:58:20 -06:00
.. option :: verific_read_lib_name<lib_label>=<lib_name>
2021-10-29 08:34:27 -05:00
2022-01-17 03:58:20 -06:00
The `` lib_label `` variable can be any number of string without
white-spaces. The option specifies library name where Verilog/SystemVerilog/VHDL files specified by `` verific_read_lib_src<lib_label> `` option will be loaded. This option should be used only with `` verific_read_lib_src<lib_label> `` option.
2021-10-29 08:34:27 -05:00
2022-01-17 03:58:20 -06:00
.. option :: verific_read_lib_src<lib_label>=<library_src_files>
2021-10-29 08:34:27 -05:00
2022-01-17 03:58:20 -06:00
The `` lib_label `` variable can be any number of string without
white-spaces. The option specifies Verilog/SystemVerilog/VHDL files to be loaded into library specified by `` verific_read_lib_name<lib_label> `` option. The `` library_src_files `` should be the source files names separated by commas. This option should be used only with `` verific_read_lib_name<lib_label> `` option.
2021-10-29 08:34:27 -05:00
.. option :: verific_search_lib=<lib_name>
The option specifies library name from where will look up for external definitions while reading HDL files.
.. option :: yosys_cell_sim_verilog=<verilog_files>
The option specifies Verilog files which should be separated by comma.
.. option :: yosys_cell_sim_systemverilog=<systemverilog_files>
The option specifies SystemVerilog files which should be separated by comma.
.. option :: yosys_cell_sim_vhdl=<vhdl_files>
The option specifies VHDL files which should be separated by comma.
.. option :: yosys_blackbox_modules=<blackbox_modules>
The option specifies blackbox modules names which should be separated by comma (usually these are the modules defined in files specified with yosys_cell_sim_<verilog/systemverilog/vhdl> option).
2019-09-01 23:15:53 -05:00
Architectures Sections
^^^^^^^^^^^^^^^^^^^^^^
2019-09-02 03:45:05 -05:00
User can define the list of architecture files in this section.
2019-09-01 23:15:53 -05:00
.. option :: arch<arch_label>=<xml_architecture_file_path>
The `` arch_label `` variable can be any number of string without
white-spaces. `` xml_architecture_file_path `` is path to the actual XML
architecture file
.. note ::
2019-09-02 03:45:05 -05:00
In the final OpenFPGA Task result, the architecture will be referred by its
2019-09-01 23:15:53 -05:00
`` arch_label `` .
Benchmarks Sections
^^^^^^^^^^^^^^^^^^^
User can define the list of benchmarks files in this section.
.. option :: bench<bench_label>=<list_of_files_in_benchmark>
The `` bench_label `` variable can be any number of string without
2022-01-18 03:07:41 -06:00
white-spaces. `` list_of_files_in_benchmark `` is a list of benchmark HDL files paths.
2019-09-01 23:15:53 -05:00
For Example following code shows how to define a benchmarks,
2019-09-02 03:45:05 -05:00
with a single file, multiple files and files added from a specific directory.
2019-09-01 23:15:53 -05:00
.. code-block :: text
[BENCHMARKS]
# To declare single benchmark file
bench_design1=${BENCH_PATH}/design/top.v
# To declare multiple benchmark file
bench_design2=${BENCH_PATH}/design/top.v,${BENCH_PATH}/design/sub_module.v
# To add all files in specific directory to the benchmark
bench_design3=${BENCH_PATH}/design/top.v,${BENCH_PATH}/design/lib/*.v
.. note ::
`` bench_label `` is referred again in `` Synthesis_Param `` section to
2019-09-02 03:45:05 -05:00
provide additional information about benchmark
2019-09-01 23:15:53 -05:00
Synthesis Parameter Sections
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2019-09-02 03:45:05 -05:00
User can define extra parameters for each benchmark in the
2019-09-01 23:15:53 -05:00
`` BENCHMARKS `` sections.
.. option :: bench<bench_label>_top=<Top_Module_Name>
2019-09-02 03:45:05 -05:00
This option defines the Top Level module name for `` bench_label `` benchmark.
By default, the top-level module name is considered as a `` top `` .
2019-09-01 23:15:53 -05:00
.. option :: bench<bench_label>_yosys_tmpl=<yosys_template_file>
[TODO]
.. option :: bench<bench_label>_chan_width=<chan_width_to_use>
In case of running fixed channel width routing for each benchmark,
this option defines the channel width to be used for `` bench_label ``
benchmark
.. option :: bench<bench_label>_act=<activity_file_path>
In case of running `` blif_vpr_flow `` this option provides the activity files
to be used to generate testbench for `` bench_label `` benchmark
.. option :: bench<bench_label>_verilog=<source_verilog_file_path>
In case of running `` blif_vpr_flow `` with verification this option provides
2019-09-02 03:45:05 -05:00
the source Verilog design for `` bench_label `` benchmark to be used
2019-09-01 23:15:53 -05:00
while verification.
2022-01-17 08:42:40 -06:00
.. option :: bench<bench_label>_read_verilog_options=<Options>
This option defines the `` read_verilog `` command options for `` bench_label `` benchmark.
If all benchmarks share the same options then `` bench_read_verilog_options_common `` can be used to define common options.
2019-09-01 23:15:53 -05:00
Script Parameter Sections
^^^^^^^^^^^^^^^^^^^^^^^^^
The script parameter section lists set of commnad line pararmeters to be passed to :ref: `run_fpga_flow` script. The section name is defines as `` SCRIPT_PARAM_<parameter_set_label> `` where `parameter_set_label` can be any word without white spaces.
2019-09-02 03:45:05 -05:00
The section is referred with `` parameter_set_label `` in the final result file.
2019-09-01 23:15:53 -05:00
For example following code Specifies the two sets (`` Fixed_Routing_30 `` and `` Fixed_Routing_50 `` ) of :ref: `run_fpga_flow` arguments.
.. code-block :: text
[SCRIPT_PARAM_Fixed_Routing_30]
# Execute fixed routing with channel with 30
fix_route_chan_width=30
[SCRIPT_PARAM_Fixed_Routing_50]
# Execute fixed routing with channel with 50
fix_route_chan_width=50
Example Task Configuration File
2019-09-02 03:45:05 -05:00
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2019-09-01 23:15:53 -05:00
.. code-block :: text
[GENERAL]
spice_output=false
verilog_output=false
power_analysis = true
power_tech_file = ${PATH:TECH_PATH}/winbond90nm/winbond90nm_power_properties.xml
timeout_each_job = 20*60
[ARCHITECTURES]
arch0=${PATH:ARCH_PATH}/winbond90/k6_N10_rram_memory_bank_SC_winbond90.xml
[BENCHMARKS]
bench0=${PATH:BENCH_PATH}/MCNC_Verilog/s298/s298.v
bench1=${PATH:BENCH_PATH}/MCNC_Verilog/elliptic/elliptic.v
[SYNTHESIS_PARAM]
bench0_top = s298
bench1_top = elliptic
[SCRIPT_PARAM_Slack_30]
min_route_chan_width=1.3
[SCRIPT_PARAM_Slack_80]
min_route_chan_width=1.8