aboutsummaryrefslogtreecommitdiffstats
path: root/README.md
diff options
context:
space:
mode:
Diffstat (limited to 'README.md')
-rw-r--r--README.md42
1 files changed, 28 insertions, 14 deletions
diff --git a/README.md b/README.md
index 195f08c3..da38500d 100644
--- a/README.md
+++ b/README.md
@@ -5,6 +5,7 @@ Supported Architectures
-----------------------
- iCE40
+- ECP5
Prequisites
-----------
@@ -23,23 +24,30 @@ Prequisites
- For building on macOS, brew utility is needed.
- Install all needed packages `brew install cmake python boost boost-python3 qt5`
- Do not forget to add qt5 in path as well `echo 'export PATH="/usr/local/opt/qt/bin:$PATH"' >> ~/.bash_profile`
-
+ - For ECP5 support, you must download [Project Trellis](https://github.com/SymbiFlow/prjtrellis), then follow its instructions to
+ download the latest database and build _libtrellis_.
+
+
Building
--------
+ - Specifying target architecture is mandatory use ARCH parameter to set it. It is semicolon separated list.
+ - Use `cmake . -DARCH=all` to build all supported targets
+ - For example `cmake . -DARCH=ice40` would build just ICE40 support
- Use CMake to generate the Makefiles (only needs to be done when `CMakeLists.txt` changes)
- - For a debug build, run `cmake -DCMAKE_BUILD_TYPE=Debug .`
- - For a debug build with HX1K support only, run ` cmake -DCMAKE_BUILD_TYPE=Debug -DICE40_HX1K_ONLY=1 .`
- - For a release build, run `cmake .`
+ - For an iCE40 debug build, run `cmake -DARCH=ice40 -DCMAKE_BUILD_TYPE=Debug .`
+ - For an iCE40 debug build with HX1K support only, run `cmake -DARCH=ice40 -DCMAKE_BUILD_TYPE=Debug -DICE40_HX1K_ONLY=1 .`
+ - For an iCE40 and ECP5 release build, run `cmake -DARCH="ice40;ecp5" .`
- Add `-DCMAKE_INSTALL_PREFIX=/your/install/prefix` to use a different install prefix to the default `/usr/local`
- - For MSVC build with vcpkg use `cmake . -DCMAKE_TOOLCHAIN_FILE=C:/vcpkg/scripts/buildsystems/vcpkg.cmake` using your vcpkg location
+ - For MSVC build with vcpkg use `-DCMAKE_TOOLCHAIN_FILE=C:/vcpkg/scripts/buildsystems/vcpkg.cmake` using your vcpkg location
- For MSVC x64 build adding `-G"Visual Studio 14 2015 Win64"` is needed.
+ - For ECP5 support, you must also specify the path to Project Trellis using `-DTRELLIS_ROOT=/path/trellis`
- Use Make to run the build itself
- For all binary targets, just run `make`
- For just the iCE40 CLI&GUI binary, run `make nextpnr-ice40`
- - To build binary without Python support, run `cmake -DBUILD_PYTHON=OFF .`
- - To build binary without GUI, run `cmake -DBUILD_GUI=OFF .`
- - For minimal binary without Python and GUI, run `cmake -DBUILD_PYTHON=OFF -DBUILD_GUI=OFF .`
+ - To build binary without Python support, use `-DBUILD_PYTHON=OFF`
+ - To build binary without GUI, use `-DBUILD_GUI=OFF`
+ - For minimal binary without Python and GUI, use `-DBUILD_PYTHON=OFF -DBUILD_GUI=OFF`
- For just the iCE40 Python module, run `make nextpnrpy_ice40`
- Using too many parallel jobs may lead to out-of-memory issues due to the significant memory needed to build the chipdbs
- To install nextpnr, run `make install`
@@ -47,12 +55,12 @@ Building
Testing
-------
- - To build test binaries as well, run `cmake -DBUILD_TESTS=OFF .` and after run `make tests` to run them, or you can run separate binaries.
- - To use code sanitizers use:
- - `cmake . -DSANITIZE_ADDRESS=ON`
- - `cmake . -DSANITIZE_MEMORY=ON -DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++`
- - `cmake . -DSANITIZE_THREAD=ON`
- - `cmake . -DSANITIZE_UNDEFINED=ON`
+ - To build test binaries as well, use `-DBUILD_TESTS=OFF` and after run `make tests` to run them, or you can run separate binaries.
+ - To use code sanitizers use the `cmake` options:
+ - `-DSANITIZE_ADDRESS=ON`
+ - `-DSANITIZE_MEMORY=ON -DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++`
+ - `-DSANITIZE_THREAD=ON`
+ - `-DSANITIZE_UNDEFINED=ON`
- Running valgrind example `valgrind --leak-check=yes --tool=memcheck ./nextpnr-ice40 --json ice40/blinky.json`
Running
@@ -65,6 +73,12 @@ Running
produce `blinky.json`.
- To place-and-route the blinky using nextpnr, run `./nextpnr-ice40 --hx1k --json ice40/blinky.json --pcf ice40/blinky.pcf --asc blinky.asc`
+ - For an ECP5 blinky, first synthesise using `yosys blinky.ys` in `ecp5/synth`.
+ - Then run ECP5 place-and route using
+ `./nextpnr-ecp5 --json ecp5/synth/blinky.json --basecfg ecp5/synth/ulx3s_empty.config --bit ecp5/synth/ulx3s.bit`
+ - Note that `ulx3s_empty.config` contains fixed/unknown bits to be copied to the output bitstream
+ - You can also use `--textcfg out.config` to write a text file describing the bitstream for debugging
+
Notes
-------