diff options
| author | gatecat <gatecat@ds0.me> | 2021-02-19 08:41:58 +0000 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2021-02-19 08:41:58 +0000 | 
| commit | 5dcb59b13decab276ac736b0b06b4ccebcf83f62 (patch) | |
| tree | 67017806da1d36a6ec13fc538390b875b30309ab /fpga_interchange/examples/create_bba | |
| parent | b4a97efe4da95084ba5585c48d20681f68742fd4 (diff) | |
| parent | c21e23b3eb6fee48c2b2da384b2dd0cd2d4ad91f (diff) | |
| download | nextpnr-5dcb59b13decab276ac736b0b06b4ccebcf83f62.tar.gz nextpnr-5dcb59b13decab276ac736b0b06b4ccebcf83f62.tar.bz2 nextpnr-5dcb59b13decab276ac736b0b06b4ccebcf83f62.zip | |
Merge pull request #576 from litghost/add_cell_bel_pin_mapping
Complete FPGA interchange Arch to the point where it can route a wire
Diffstat (limited to 'fpga_interchange/examples/create_bba')
| -rw-r--r-- | fpga_interchange/examples/create_bba/Makefile | 91 | ||||
| -rw-r--r-- | fpga_interchange/examples/create_bba/README.md | 40 | 
2 files changed, 131 insertions, 0 deletions
| diff --git a/fpga_interchange/examples/create_bba/Makefile b/fpga_interchange/examples/create_bba/Makefile new file mode 100644 index 00000000..3033daca --- /dev/null +++ b/fpga_interchange/examples/create_bba/Makefile @@ -0,0 +1,91 @@ +# +#  nextpnr -- Next Generation Place and Route +# +#  Copyright (C) 2021  Symbiflow Authors +# +# +#  Permission to use, copy, modify, and/or distribute this software for any +#  purpose with or without fee is hereby granted, provided that the above +#  copyright notice and this permission notice appear in all copies. +# +#  THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES +#  WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF +#  MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR +#  ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +#  WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +#  ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF +#  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + + +# This Makefile provides a streamlined way to create an example +# FPGA interchange BBA suitable for placing and routing on Xilinx A35 parts. +# +# FPGA interchange device database is generated via RapidWright. +# +# Currently FPGA interchange physical netlist (e.g. place and route route) to +# FASM support is not done, so bitstream generation relies on RapidWright to +# convert FPGA interchange logical and physical netlist into a Vivado DCP. + +include ../common.mk + +.DELETE_ON_ERROR: + +.PHONY: all chipdb + +all: chipdb + +build: +	mkdir build + +build/RapidWright: | build +	# FIXME: Update URL / branch as fixes are merged upstream and / or +	# interchange branch on Xilinx/RapidWright is merged to master branch. +	# +	#cd build && git clone -b interchange https://github.com/Xilinx/RapidWright.git +	cd build && git clone -b move_strlist https://github.com/litghost/RapidWright.git + +build/env: | build +	python3 -mvenv build/env + +build/python-fpga-interchange: | build +	cd build && git clone https://github.com/SymbiFlow/python-fpga-interchange.git + +build/fpga-interchange-schema: | build +	cd build && git clone https://github.com/SymbiFlow/fpga-interchange-schema.git + +build/.setup: | build/env build/fpga-interchange-schema build/python-fpga-interchange build/RapidWright +	source build/env/bin/activate && \ +		cd build/python-fpga-interchange/ && \ +		pip install -r requirements.txt +	touch build/.setup + +$(NEXTPNR_PATH)/build: +	mkdir $(NEXTPNR_PATH)/build + +$(NEXTPNR_PATH)/build/bba/bbasm: | $(NEXTPNR_PATH)/build +	cd $(NEXTPNR_PATH)/build && cmake -DARCH=fpga_interchange .. +	make -j -C $(NEXTPNR_PATH)/build + +$(NEXTPNR_PATH)/fpga_interchange/chipdb.bba: build/.setup +	mkdir -p build/nextpnr/fpga_interchange +	source build/env/bin/activate && \ +		cd build/python-fpga-interchange/ && \ +		make \ +		-f Makefile.rapidwright \ +		NEXTPNR_PATH=$(realpath .)/build/nextpnr \ +		RAPIDWRIGHT_PATH=$(RAPIDWRIGHT_PATH) \ +		INTERCHANGE_PATH=$(INTERCHANGE_PATH) + +$(BBA_PATH): $(NEXTPNR_PATH)/build/bba/bbasm $(NEXTPNR_PATH)/fpga_interchange/chipdb.bba +	$(NEXTPNR_PATH)/build/bba/bbasm -l build/nextpnr/fpga_interchange/chipdb.bba $(BBA_PATH) + +chipdb: $(BBA_PATH) + +test: chipdb +	$(NEXTPNR_PATH)/build/nextpnr-fpga_interchange \ +		--chipdb $(BBA_PATH) \ +		--package csg324 \ +		--test + +clean: +	rm -rf build diff --git a/fpga_interchange/examples/create_bba/README.md b/fpga_interchange/examples/create_bba/README.md new file mode 100644 index 00000000..d2ca5188 --- /dev/null +++ b/fpga_interchange/examples/create_bba/README.md @@ -0,0 +1,40 @@ +## Makefile-driven BBA creation + +This Makefile will generate a Xilinx A35 chipdb if java, capnproto and +capnproto-java are installed. + +### Installing dependencies + +Install java and javac if not already installed: +``` +# Or equivalent for your local system. +sudo apt-get install openjdk-10-jdk +``` + +Install capnproto if not already installed: +``` +# Or equivalent for your local system. +sudo apt-get install capnproto libcapnp-dev +``` + +Install capnproto-java if not already installed: +``` +git clone https://github.com/capnproto/capnproto-java.git +cd capnproto-java +make +sudo make install +``` + +### Instructions + +Once dependencies are installed, just run "make".  This should download +remaining dependencies and build the chipdb and build nextpnr if not built. + +#### Re-building the chipdb + +``` +# Remove the text BBA +rm build/nextpnr/fpga_interchange/chipdb.bba +# Build the BBA +make +``` | 
