Lattice ECP5¶
The torii.platform.vendor.lattice.ecp5 module provides a base platform to support Lattice ECP5 devices with the Trellis and Diamond toolchains.
- class torii.platform.vendor.lattice.ecp5.ECP5Platform(*, toolchain: Literal['Trellis', 'Diamond'] = 'Trellis') None¶
- Trellis toolchain - Required tools:
- yosys
- nextpnr-ecp5
- ecppack
 
 - The environment is populated by running the script specified in the environment variable - TORII_ENV_TRELLIS, if present.- Available overrides:
- verbose: enables logging of informational messages to standard error.
- read_verilog_opts: adds options for- read_verilogYosys command.
- synth_opts: adds options for- synth_ecp5Yosys command.
- script_after_read: inserts commands after- read_rtlilin Yosys script.
- script_after_synth: inserts commands after- synth_ecp5in Yosys script.
- yosys_opts: adds extra options for- yosys.
- nextpnr_opts: adds extra options for- nextpnr-ecp5.
- ecppack_opts: adds extra options for- ecppack.
- add_preferences: inserts commands at the end of the LPF file.
 
- Build products:
- {{name}}.rpt: Yosys log.
- {{name}}.json: synthesized RTL.
- {{name}}.tim: nextpnr log.
- {{name}}.config: ASCII bitstream.
- {{name}}.bit: binary bitstream.
- {{name}}.svf: JTAG programming vector.
 
 - Diamond toolchain - Required tools:
- pnmainc
- ddtcmd
 
 - The environment is populated by running the script specified in the environment variable - TORII_ENV_DIAMOND, if present. On Linux, diamond_env as provided by Diamond itself is a good candidate. On Windows, the following script (named- diamond_env.bat, for instance) is known to work:- @echo off set PATH = C:\lscc\diamond\%DIAMOND_VERSION%\bin\nt64;%PATH% - Available overrides:
- script_project: inserts commands before- prj_project savein Tcl script.
- script_after_export: inserts commands after- prj_run Exportin Tcl script.
- add_preferences: inserts commands at the end of the LPF file.
- add_constraints: inserts commands at the end of the XDC file.
 
- Build products:
- {{name}}_impl/{{name}}_impl.htm: consolidated log.
- {{name}}.bit: binary bitstream.
- {{name}}.svf: JTAG programming vector.