custom boards - zapta/apio-new-doc-wiki.delete-me GitHub Wiki
Using Custom Boards
Apio uses definitions of FPGA devices, FPGA programmers, and FPGA boards to simplify the setup of new projects. The diagram below illustrates the relationship between these definitions and Apio's operation, as well as the names of their respective definition files located in the Apio resources directory.
graph TD
fpga["FPGA Definition<br>(fpgas.jsonc)"]
programmer["Programmer Definition<br>(programmers.jsonc)"]
board["Board Definition<br>(boards.jsonc)"]
synth["Synthesizing"]
prog["Programming"]
fpga --> board
programmer --> board
board --> synth
board --> prog
synth --> prog
style fpga fill:#ffff33,rx:10,ry:10
style programmer fill:#ffff33,rx:10,ry:10
style board fill:#ffff33,rx:10,ry:10
style synth rx:10,ry:10
style prog rx:10,ry:10
If any of these default definitions do not match the FPGA board you are using, you can override them by placing custom definition files in the top-level directory of your project. These replacement files should:
- Use the same file names and formats as the originals (
fpgas.jsonc
,programmers.jsonc
, orboards.jsonc
). - Include only the specific FPGA, programmer, or board definitions you need.
Resource Files
Resource File | Contains | Keyed By |
---|---|---|
fpgas.jsonc |
FPGA definitions | fpga-id |
programmers.jsonc |
Programmer definitions | programmer-id |
boards.jsonc |
Board definitions | board-id |
If you believe your custom definition may be useful to others, consider submitting a pull request to the appropriate Apio resource file.
boards.jsonc
Example: Custom The following is an example of a custom boards.jsonc
file that defines
a variant of the upduino31
board:
{
"upduino31c": {
"name": "UPduino v3.1c",
"fpga": "ice40up5k-sg48",
"programmer": {
"type": "iceprog"
},
"usb": {
"vid": "0403",
"pid": "6010",
"product-regex": "UPduino v3\\.1c"
}
}
}
Note: Custom definitions must be compatible with the underlying toolchain. Defining an unsupported FPGA may result in synthesis errors.