Skip to content

Commit

Permalink
Merge pull request f4pga#2485 from antmicro/umarcor/doc/cmake
Browse files Browse the repository at this point in the history
docs: move cmake.md into the Sphinx site
  • Loading branch information
kgugala authored Mar 14, 2022
2 parents 243a64e + 69d617b commit 3d9cb66
Show file tree
Hide file tree
Showing 6 changed files with 94 additions and 94 deletions.
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -17,3 +17,6 @@ model.xml
pb_type.xml
*.sort.xml
*~

/docs/_build/
/docs/_theme/
87 changes: 0 additions & 87 deletions cmake.md

This file was deleted.

9 changes: 3 additions & 6 deletions docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,16 +24,13 @@
master_doc = 'index'

extensions = [
'sphinx.ext.autodoc',
'sphinx.ext.extlinks',
'sphinx.ext.intersphinx',
'sphinxcontrib.images',
'sphinx.ext.autodoc', 'sphinx.ext.extlinks', 'sphinx.ext.intersphinx',
'sphinxcontrib.images', 'myst_parser'
]

templates_path = ['_templates']

# source_suffix = ['.rst', '.md']
source_suffix = '.rst'
source_suffix = {'.rst': 'restructuredtext', '.md': 'markdown'}

language = None

Expand Down
85 changes: 85 additions & 0 deletions docs/development/cmake.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,85 @@
# CMake build system

## Variables

* `USE_CONDA` - Whether to rely on conda to supply external binaries (e.g. yosys, vpr).

* `VPR_BASE_ARGS` - Base VPR arguments used during pack, place and route.
{ghsrc}`Default arguments <common/cmake/devices.cmake#L454>`.

* `VPR_EXTRA_ARGS` - Additional arguments to pass to VPR during pack, place and route.

To set CMake variable, use the -D flag during the configuration process.
Example:

```bash
mkdir build
cd build
cmake -DUSE_CONDA=FALSE ..
make
```

## Terminology

The CMake system in f4pga-arch-defs uses the following hierarchy:

* `ARCH` - Architecture is the high level grouping of a set of "similar" FPGA types.
An example would be the "Lattice iCE40 Series" (ice40) or the "Xilinx Artix 7 Series" (artix7).

* `DEVICE_TYPE` - A type of device.
This is defined as an `ARCH` and the arch.xml which defines the units with this device type.

* `DEVICE` - A specific instance of a `DEVICE_TYPE`.
A device definition is a `DEVICE_TYPE`, a `PACKAGE` list, and IO map definitions for each package if needed.
Each `DEVICE` should correspond with a layout definition within the `DEVICE_TYPE`.

* `BOARD` - A specific `DEVICE` and `PACKAGE` instance, along with a `PROG_TOOL`/`PROG_CMD` (e.g. commands to program a
specified board).

## Creating a new FPGA target

If you are familiar with cmake, `ADD_FPGA_TARGET` is the rough equivalent to the normal `ADD_EXECUTABLE` target you
would use with a C project.

`ADD_FPGA_TARGET` will create the targets needed to take a design from Verilog to bitstream through the synthesis, place
and route, bitstream and potentially even programming.
The required arguments are the `BOARD` and input files see {ghsrc}`ADD_FPGA_TARGET documentation <common/cmake/devices.cmake#L559>`
for further information on other target configuration options.

If you want to target multiple boards, `ADD_FPGA_TARGET_BOARDS` exists that will call `ADD_FPGA_TARGET` correctly for
each board you request.
See {ghsrc}`ADD_FPGA_TARGET_BOARDS documentation <common/cmake/devices.cmake#L458>`.

### Note on `ADD_FILE_TARGET` and `ADD_FPGA_BOARD`

All source files in the f4pga-arch-defs are required to have a file target associated with them.
This is done via {ghsrc}`ADD_FILE_TARGET <common/cmake/file_targets.cmake#L193>`.
By default `ADD_FPGA_TARGET` and `ADD_FPGA_TARGET_BOARDS` will both implicitly invoke `ADD_FILE_TARGET` for you.
This handles the common case where input sources are not generated files.
However, if you are using generated files, then you will need to add `ADD_FILE_TARGET` calls for all inputs to
`ADD_FPGA_TARGET`.

For non-generated verilog, `ADD_FILE_TARGET` should be invoked like:

```cmake
add_file_target(FILE <current source dir relative path> SCANNER_TYPE verilog)
```

For generated verilog, `ADD_FILE_TARGET` should be invoked like:

```cmake
add_file_target(FILE <current source dir relative path> GENERATED)
```

Note that the input path must be current source dir relative, not absolute, and not relative to the cmake current binary
dir.
Also note that CMake cannot take depedendencies during build time, so for generated files you must supply the
dependencies for the target.
See {ghsrc}`APPEND_FILE_DEPENDENCY <common/cmake/file_targets.cmake#L79>` for adding dependencies to other file targets.

It is generally suggested that all source forms within f4pga-arch-defs are file targets, but it is required for
verilog files because of how verilog handles relative include paths.
Verilog defines relative paths as relative to the location of the file, not to the location of the compiler.
As a result, if you use relative includes to include both a generated and non-generated file, unless the files are moved
to a unified source tree, verilog relative includes will not work.
`ADD_FILE_TARGET` solves this by copying non-generated files to the binary directory.
3 changes: 2 additions & 1 deletion docs/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,9 @@ Contents

.. toctree::
:maxdepth: 2
:caption: Development Practices
:caption: Development

development/cmake
development/structure
development/vtr_notes

Expand Down
1 change: 1 addition & 0 deletions docs/requirements.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
myst-parser
sphinx
http://github.com/SymbiFlow/sphinx_symbiflow_theme/archive/chips.zip#sphinx-symbiflow-theme
sphinxcontrib-images

0 comments on commit 3d9cb66

Please sign in to comment.