nextpnr portable FPGA place and route tool
Go to file
Clifford Wolf d85f5d2285 Remove now obsolete ice40/makefile.inc
Signed-off-by: Clifford Wolf <clifford@clifford.at>
2018-06-02 14:49:32 +02:00
common Python bindings working on both architectures 2018-06-02 13:48:28 +02:00
dummy Python bindings working on both architectures 2018-06-02 13:48:28 +02:00
ice40 Remove now obsolete ice40/makefile.inc 2018-06-02 14:49:32 +02:00
python Python bindings working on both architectures 2018-06-02 13:48:28 +02:00
.gitignore Add a CMake based build system 2018-06-02 13:48:28 +02:00
CMakeLists.txt Improve documentation in CMakeLists.txt 2018-06-02 13:48:28 +02:00
README.md Update README with CMake instructions 2018-06-02 13:57:08 +02:00

nextpnr -- a portable FPGA place and route tool

Supported Architectures

  • iCE40

Prequisites

  • CMake 3.3 or later
  • Modern C++11 compiler, clang recommended
  • Python 3.5 or later, including development libraries (python3-dev for Ubuntu)
  • Boost libraries (libboost-all-dev for Ubuntu)
  • Icestorm, with chipdbs installed in /usr/local/share/icebox

Building

  • 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 release build, run cmake .
  • Use Make to run the build itself
    • For all targets, just run make
    • For just the iCE40 CLI binary, run make nextpnr-ice40
    • 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

Running

  • To run the CLI binary, just run ./nextpnr-ice40
  • The Python module is called nextpnrpy_ice40.so. To test it, run PYTHONPATH=. python3 python/python_test.py