Skip to content

Latest commit

 

History

History
1011 lines (715 loc) · 29.1 KB

COMMANDS.md

File metadata and controls

1011 lines (715 loc) · 29.1 KB

APIO COMMANDS


apio

Usage: apio [OPTIONS] COMMAND [ARGS]...

  Work with FPGAs with ease.

  Apio is an easy to use and open-source command-line suite designed to
  streamline FPGA programming. It supports a wide range of tasks, including
  linting, building, simulation, unit testing, and programming FPGA boards.

  An Apio project consists of a directory containing a configuration file
  named 'apio.ini', along with FPGA source files, testbenches, and pin
  definition files.

  Apio commands are intuitive and perform their intended functionalities right
  out of the box. For example, the command apio upload automatically compiles
  the design in the current directory and uploads it to the FPGA board.

  For detailed information about any Apio command, append the -h flag to view
  its help text. For instance:

  apio build -h
  apio drivers ftdi install -h

  For more information about the Apio project, visit the official Apio Wiki
  https://github.com/FPGAwars/apio/wiki/Apio

Options:
  --version   Show the version and exit.
  -h, --help  Show this message and exit.

Build commands:
  apio build        Synthesize the bitstream.
  apio upload       Upload the bitstream to the FPGA.
  apio clean        Delete the apio generated files.

Verification commands:
  apio lint         Lint the verilog code.
  apio format       Format verilog source files.
  apio sim          Simulate a testbench with graphic results.
  apio test         Test all or a single verilog testbench module.
  apio report       Report design utilization and timing.
  apio graph        Generate a visual graph of the code.

Setup commands:
  apio create       Create an apio.ini project file.
  apio preferences  Manage the apio user preferences.
  apio packages     Manage the apio packages.
  apio drivers      Manage the operating system drivers.

Utility commands:
  apio boards       List available board definitions.
  apio fpgas        List available FPGA definitions.
  apio examples     List and fetch apio examples.
  apio system       Provides system info.
  apio raw          Execute commands directly from the Apio packages.
  apio upgrade      Check the latest Apio version.


apio boards

Usage: apio boards [OPTIONS]

  The command 'apio boards' lists the FPGA boards recognized by Apio. Custom
  boards can be defined by placing a custom 'boards.jsonc' file in the project
  directory, which will override Apio’s default 'boards.jsonc' file.

  Examples:
    apio boards                   # List all boards.
    apio boards -v                # List with extra columns..
    apio boards | grep ecp5       # Filter boards results.

Options:
  -v, --verbose           Show detailed output.
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio build

Usage: apio build [OPTIONS]

  The command 'apio build' processes the project’s source files and generates
  a bitstream file, which can then be uploaded to your FPGA.

  The 'apio build' command compiles all .v files (e.g., my_module.v) in the
  project directory, except those whose names end with _tb (e.g.,
  my_module_tb.v), as these are assumed to be testbenches.

  Examples:
    apio build       # Build
    apio build -v    # Build with verbose info

Options:
  -p, --project-dir path  Set the root directory for the project.
  -v, --verbose           Show detailed output.
  --verbose-synth         Show detailed synth stage output.
  --verbose-pnr           Show detailed pnr stage output.
  -h, --help              Show this message and exit.

apio clean

Usage: apio clean [OPTIONS]

  The command 'apio clean' removes temporary files generated in the project
  directory by previous Apio commands.

  Example:
    apio clean

Options:
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio create

Usage: apio create [OPTIONS]

  The command 'apio create' creates a new `apio.ini` project file and is
  typically used when setting up a new Apio project.

  Examples:
    apio create --board alhambra-ii
    apio create --board alhambra-ii --top-module MyModule

  [Note] This command only creates a new 'apio.ini' file, rather than a
  complete and buildable project. To create complete projects, refer to the
  'apio examples' command.

Options:
  -b, --board BOARD       Set the board.  [required]
  -t, --top-module name   Set the top level module name.
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio drivers

Usage: apio drivers [OPTIONS] COMMAND [ARGS]...

  The command group ‘apio drivers’ contains subcommands to manage the drivers
  on your system.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio drivers list       List system drivers.
  apio drivers install    Install drivers.
  apio drivers uninstall  Uninstall drivers.


apio drivers install

Usage: apio drivers install [OPTIONS] COMMAND [ARGS]...

  The command group 'apio drivers install' includes subcommands that that
  install system drivers that are used to upload designs to FPGA boards.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio drivers install ftdi    Install the ftdi drivers.
  apio drivers install serial  Install the serial drivers.


apio drivers install ftdi

Usage: apio drivers install ftdi [OPTIONS]

  The command 'apio drivers install ftdi' installs on your system the FTDI
  drivers required by some FPGA boards.

  Examples:
    apio drivers install ftdi     # Install the ftdi drivers.

Options:
  -h, --help  Show this message and exit.

apio drivers install serial

Usage: apio drivers install serial [OPTIONS]

  The command ‘apio drivers install serial’ installs the necessary serial
  drivers on your system, as required by certain FPGA boards.

  Examples:
    apio drivers install serial    # Install the serial drivers.

Options:
  -h, --help  Show this message and exit.

apio drivers list

Usage: apio drivers list [OPTIONS] COMMAND [ARGS]...

  The command group 'apio drivers list' includes subcommands that that lists
  system drivers that are used with FPGA boards.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio drivers list ftdi    List the connected ftdi devices.
  apio drivers list serial  List the connected serial devices.
  apio drivers list usb     List connected USB devices.


apio drivers list ftdi

Usage: apio drivers list ftdi [OPTIONS]

  The command 'apio drivers list ftdi' displays the FTDI devices currently
  connected to your computer. It is useful for diagnosing FPGA board
  connectivity issues.

  Examples:
    apio drivers list ftdi     # List the ftdi devices.

  [Hint] This command uses the lsftdi utility, which can also be invoked
  directly with the 'apio raw -- lsftdi <flags>' command.

Options:
  -h, --help  Show this message and exit.

apio drivers list serial

Usage: apio drivers list serial [OPTIONS]

  The command ‘apio drivers list serial’ lists the serial devices connected to
  your computer. It is useful for diagnosing FPGA board connectivity issues.

  Examples:
    apio drivers list serial    # List the serial devices.

  [Hint] This command executes the utility lsserial, which can also be invoked
  using the command 'apio raw -- lsserial <flags>'.

Options:
  -h, --help  Show this message and exit.

apio drivers list usb

Usage: apio drivers list usb [OPTIONS]

  The command ‘apio drivers list usb runs the lsusb utility to list the USB
  devices connected to your computer. It is typically used for diagnosing
  connectivity issues with FPGA boards.

  Examples:
    apio drivers list usb      # List the usb devices

  [Hint] You can also run the lsusb utility using the command 'apio raw --
  lsusb <flags>'.

Options:
  -h, --help  Show this message and exit.

apio drivers uninstall

Usage: apio drivers uninstall [OPTIONS] COMMAND [ARGS]...

  The command group 'apio drivers uninstall' includes subcommands that that
  uninstall system drivers that are used to upload designs to FPGA boards.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio drivers uninstall ftdi    Uninstall the ftdi drivers.
  apio drivers uninstall serial  Uninstall the serial drivers.


apio drivers uninstall ftdi

Usage: apio drivers uninstall ftdi [OPTIONS]

  The command 'apio drivers uninstall ftdi' removes the FTDI drivers that may
  have been installed earlier.

  Examples:
    apio drivers uninstall ftdi     # Uninstall the ftdi drivers.

Options:
  -h, --help  Show this message and exit.

apio drivers uninstall serial

Usage: apio drivers uninstall serial [OPTIONS]

  The command ‘apio drivers uninstall serial’ removes the serial drivers that
  you may have installed earlier.

  Examples:
    apio drivers uinstall serial    # Uinstall the serial drivers.

Options:
  -h, --help  Show this message and exit.

apio examples

Usage: apio examples [OPTIONS] COMMAND [ARGS]...

  The command group ‘apio examples’ provides subcommands for listing and
  fetching Apio-provided examples. Each example is a self-contained mini-
  project that can be built and uploaded to an FPGA board.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio examples list         List the available apio examples.
  apio examples fetch        Fetch the files of an example.
  apio examples fetch-board  Fetch all examples of a board.


apio examples fetch

Usage: apio examples fetch [OPTIONS] EXAMPLE

  The command ‘apio examples fetch’ fetches the files of the specified example
  to the current directory or to the directory specified by the –dst option.
  The destination directory does not need to exist, but if it does, it must be
  empty.

  Examples:
    apio examples fetch alhambra-ii/ledon
    apio examples fetch alhambra-ii/ledon -d foo/bar

  [Hint] For the list of available examples, type ‘apio examples list’.

Options:
  -d, --dst path  Set a different destination directory.
  -h, --help      Show this message and exit.

apio examples fetch-board

Usage: apio examples fetch-board [OPTIONS] BOARD

  The command ‘apio examples fetch-board’ is used to fetch all the Apio
  examples for a specific board. The examples are copied to the current
  directory or to the specified destination directory if the –dst option is
  provided.

  Examples:
    apio examples fetch-board alhambra-ii             # Fetch to local directory
    apio examples fetch-board alhambra-ii -d foo/bar  # Fetch to foo/bar

  [Hint] For the list of available examples, type ‘apio examples list’.

Options:
  -d, --dst path  Set a different destination directory.
  -h, --help      Show this message and exit.

apio examples list

Usage: apio examples list [OPTIONS]

  The command ‘apio examples list’ lists the available Apio project examples
  that you can use.

  Examples:
    apio examples list                     # List all examples
    apio examples list  -v                 # List with extra information.
    apio examples list | grep alhambra-ii  # Show examples of a specific board.
    apio examples list | grep -i blink     # Show all blinking examples.



Options:
  -v, --verbose  Show detailed output.
  -h, --help     Show this message and exit.

apio format

Usage: apio format [OPTIONS] [FILES]...

  The command ‘apio format’ formats Verilog source files to ensure consistency
  and style without altering their semantics. The command accepts the names of
  pecific source files to format or formats all project source files by
  default.

  Examples:
    apio format                    # Format all source files.
    apio format -v                 # Same as above but with verbose output.
    apio format main.v main_tb.v   # Format the two tiven files.

  The format command utilizes the format tool from the Verible project, which
  can be configured by setting its flags in the apio.ini project file For
  example:

  format-verible-options =
      --column_limit=80
      --indentation_spaces=4

  If needed, sections of source code can be protected from formatting using
  Verible formatter directives:

  // verilog_format: off
  ... untouched code ...
  // verilog_format: on

  For a full list of Verible formatter flags, refer to the documentation page
  online or use the command 'apio raw -- verible-verilog-format --helpful'.

Options:
  -p, --project-dir path  Set the root directory for the project.
  -v, --verbose           Show detailed output.
  -h, --help              Show this message and exit.

apio fpgas

Usage: apio fpgas [OPTIONS]

  The command ‘apio fpgas’ lists the FPGAs recognized by Apio. Custom FPGAs
  supported by the underlying Yosys toolchain can be defined by placing a
  custom fpgas.jsonc file in the project directory, overriding Apio’s standard
  fpgas.jsonc file.

  Examples:
    apio fpgas               # List all fpgas.
    apio fpgas -v            # List with extra columns.
    apio fpgas | grep gowin  # Filter FPGA results.

Options:
  -v, --verbose           Show detailed output.
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio graph

Usage: apio graph [OPTIONS]

  The command ‘apio graph’ generates a graphical representation of the Verilog
  code in the project.

  Examples:
    apio graph               # Generate a svg file.
    apio graph --svg         # Generate a svg file.
    apio graph --pdf         # Generate a pdf file.
    apio graph --png         # Generate a png file.
    apio graph -t my_module  # Graph my_module module.

  [Hint] On Windows, type ‘explorer _build/hardware.svg’ to view the graph,
  and on Mac OS type ‘open _build/hardware.svg’.

Options:
  --svg                   Generate a svg file (default).
  --png                   Generate a png file.
  --pdf                   Generate a pdf file.
  -p, --project-dir path  Set the root directory for the project.
  -t, --top-module name   Set the name of the top module to graph.
  -v, --verbose           Show detailed output.
  -h, --help              Show this message and exit.

apio lint

Usage: apio lint [OPTIONS]

  The command ‘apio lint’ scans the project’s Verilog code and reports errors,
  inconsistencies, and style violations. The command uses the Verilator tool,
  which is included in the standard Apio installation.

  Examples:
    apio lint
    apio lint -t my_module
    apio lint --all

Options:
  -t, --top-module name   Restrict linting to this module and its depedencies.
  -a, --all               Enable all warnings, including code style warnings.
  --nostyle               Disable all style warnings.
  --nowarn nowarn         Disable specific warning(s).
  --warn warn             Enable specific warning(s).
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio packages

Usage: apio packages [OPTIONS] COMMAND [ARGS]...

  The command group ‘apio packages’ provides commands to manage the
  installation of Apio packages. These are not Python packages but Apio-
  specific packages containing various tools and data essential for the
  operation of Apio. These packages are installed after the installation of
  the Apio Python package itself, using the command ‘apio packages install’.

  The list of available packages depends on the operating system you are using
  and may vary between different operating systems.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio packages install    Install apio packages.
  apio packages uninstall  Uninstall apio packages.
  apio packages list       List apio packages.
  apio packages fix        Fix broken apio packages.


apio packages fix

Usage: apio packages fix [OPTIONS]

  The command ‘apio packages fix’ removes broken or obsolete packages that are
  listed as broken by the command ‘apio packages list’.

  Examples:
    apio packages fix     # Fix package errors, if any.

Options:
  -h, --help  Show this message and exit.

apio packages install

Usage: apio packages install [OPTIONS] PACKAGE

  The command ‘apio packages install’ installs Apio packages that are required
  for the operation of Apio on your system.

  Examples:
    apio packages install                   # Install all missing packages.
    apio packages install --force           # Re/install all missing packages.
    apio packages install oss-cad-suite     # Install just this package.
    apio packages install [email protected]   # Install a specific version.

  Adding the --force option forces the reinstallation of existing packages;
  otherwise, packages that are already installed correctly remain unchanged.

Options:
  -f, --force    Force installation.
  -v, --verbose  Show detailed output.
  -h, --help     Show this message and exit.

apio packages list

Usage: apio packages list [OPTIONS]

  The command ‘apio packages list’ lists the available and installed Apio
  packages. The list of available packages depends on the operating system you
  are using and may vary between operating systems.

  Examples:
    apio packages list

Options:
  -h, --help  Show this message and exit.

apio packages uninstall

Usage: apio packages uninstall [OPTIONS] PACKAGE

  The command ‘apio packages uninstall’ removes installed Apio packages from
  your system. The command does not uninstall the Apio tool itself.

  Examples:
    apio packages uninstall                          # Uninstall all packages
    apio packages uninstall oss-cad-suite            # Uninstall a package
    apio packages uninstall oss-cad-suite examples   # Uninstall two packages

Options:
  -v, --verbose  Show detailed output.
  -h, --help     Show this message and exit.

apio preferences

Usage: apio preferences [OPTIONS] COMMAND [ARGS]...

  The command group ‘apio preferences' contains subcommands to manage the apio
  user preferences. These are user configurations that affect all the apio
  project on the same computer.

  The user preference is not part of any apio project and typically are not
  shared when multiple user colaborate on the same project.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio preferences list  List the apio user preferences.
  apio preferences set   Set the apio user preferences.


apio preferences list

Usage: apio preferences list [OPTIONS]

  The command ‘apio preferences list’ lists the current user preferences.

  Examples:
    apio preferences list         # List the user preferences.



Options:
  -h, --help  Show this message and exit.

apio preferences set

Usage: apio preferences set [OPTIONS]

  The command ‘apio preferences set' allows to set the supported user
  preferences.

  Examples:
    apio preferences set --colors yes   # Select multi-color output.
    apio preferences set --colors no    # Select monochrome output.

  The apio colors are optimized for a terminal windows with a white
  background.

Options:
  -c, --colors [on|off]  Set/reset colors mode.  [required]
  -h, --help             Show this message and exit.

apio raw

Usage: apio raw [OPTIONS] COMMAND

  The command ‘apio raw’ allows you to bypass Apio and run underlying tools
  directly. This is an advanced command that requires familiarity with the
  underlying tools.

  Before running the command, Apio temporarily modifies system environment
  variables such as $PATH to provide access to its packages. To view these
  environment changes, run the command with the -v option.

  Examples:
    apio raw -- yosys --version           # Yosys version
    apio raw -v -- yosys --version        # Same but with verbose apio info.
    apio raw -- yosys                     # Run Yosys in interactive mode.
    apio raw -- icepll -i 12 -o 30        # Calc ICE PLL
    apio raw -v                           # Show apio env setting.
    apio raw -h                           # Show this help info.

  The -- token is used to separate Apio commands and their arguments from the
  underlying tools and their arguments. It can be omitted in some cases, but
  it’s a good practice to always use it. As a rule of thumb, always prefix the
  raw command you want to run with 'apio raw -- '.

Options:
  -v, --verbose  Show detailed output.
  -h, --help     Show this message and exit.

apio report

Usage: apio report [OPTIONS]

  The command ‘apio report’ provides information on the utilization and timing
  of the design. It is useful for analyzing utilization bottlenecks and
  verifying that the design can operate at the desired clock speed.

  Examples:
    apio report
    epio report --verbose

Options:
  -p, --project-dir path  Set the root directory for the project.
  -v, --verbose           Show detailed output.
  -h, --help              Show this message and exit.

apio sim

Usage: apio sim [OPTIONS] [TESTBENCH]

  The command ‘apio sim’ simulates the default or the specified testbench file
  and displays its simulation results in a graphical GTKWave window. The
  testbench is expected to have a name ending with _tb, such as main_tb.v or
  main_tb.sv. The default testbench file can be specified using the apio.ini
  option ‘default-testbench’. If 'default-testbench' is not specified and the
  project has exactly one testbench file, that file will be used as the
  default testbench.

  Example:
    apio sim                        # Simulate the default testbench file.
    apio sim my_module_tb.v         # Simulate the specified testbench file.

  [Important] Avoid using the Verilog $dumpfile() function in your
  testbenches, as this may override the default name and location Apio sets
  for the generated .vcd file.

  The sim command defines the INTERACTIVE_SIM macro, which can be used in the
  testbench to distinguish between ‘apio test’ and ‘apio sim’. For example,
  you can use this macro to ignore certain errors when running with ‘apio sim’
  and view the erroneous signals in GTKWave.

  For a sample testbench that utilizes this macro, see the example at:
  https://github.com/FPGAwars/apio-examples/tree/master/upduino31/testbench

  [Hint] When configuring the signals in GTKWave, save the configuration so
  you don’t need to repeat it each time you run the simulation.

Options:
  -f, --force             Force simulation.
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio system

Usage: apio system [OPTIONS] COMMAND [ARGS]...

  The command group ‘apio system’ contains subcommands that provide
  information about the system and Apio’s installation.

Options:
  -h, --help  Show this message and exit.

Subcommands:
  apio system platforms  List supported platforms ids.
  apio system info       Show platform id and other info.


apio system info

Usage: apio system info [OPTIONS]

  The command ‘apio system info’ provides general information about your
  system and Apio installation, which is useful for diagnosing Apio
  installation issues.

  Examples:
    apio system info       # Show platform id and info.

  [Advanced] The default location of the Apio home directory, where
  preferences and packages are stored, is in the .apio directory under the
  user’s home directory. This location can be changed using the APIO_HOME_DIR
  environment variable.

Options:
  -h, --help  Show this message and exit.

apio system platforms

Usage: apio system platforms [OPTIONS]

  The command ‘apio system platforms’ lists the platform IDs supported by
  Apio, with the effective platform ID of your system highlighted.

  Examples:
    apio system platforms   # List supported platform ids.

  [Advanced] The automatic platform ID detection of Apio can be overridden by
  defining a different platform ID using the APIO_PLATFORM environment
  variable.

Options:
  -h, --help  Show this message and exit.

apio test

Usage: apio test [OPTIONS] [TESTBENCH_FILE]

  The command ‘apio test’ simulates one or all the testbenches in the project
  and is useful for automated testing of your design. Testbenches are expected
  to have names ending with _tb (e.g., my_module_tb.v) and should exit with
  the $fatal directive if an error is detected.

  Examples
    apio test                 # Run all *_tb.v testbenches.
    apio test my_module_tb.v  # Run a single testbench

  [Important] Avoid using the Verilog $dumpfile() function in your
  testbenches, as this may override the default name and location Apio sets
  for the generated .vcd file.

  For a sample testbench compatible with Apio features, see:
  https://github.com/FPGAwars/apio-examples/tree/master/upduino31/testbench

  [Hint] To simulate a testbench with a graphical visualization of the
  signals, refer to the ‘apio sim’ command.

Options:
  -p, --project-dir path  Set the root directory for the project.
  -h, --help              Show this message and exit.

apio upgrade

Usage: apio upgrade [OPTIONS]

  The command ‘apio upgrade’ checks for the version of the latest Apio release
  and provides upgrade directions if necessary.

  Examples:
    apio upgrade

Options:
  -h, --help  Show this message and exit.

apio upload

Usage: apio upload [OPTIONS]

  The command ‘apio upload’ builds the bitstream file (similar to the apio
  build command) and uploads it to the FPGA board.

  Examples:
    apio upload

Options:
  --serial-port serial-port  Set the serial port.
  --ftdi-id ftdi-id          Set the FTDI id.
  -s, --sram                 Perform SRAM programming.
  -f, --flash                Perform FLASH programming.
  -p, --project-dir path     Set the root directory for the project.
  -h, --help                 Show this message and exit.