| # Copyright (C) 2017-2020 The Project X-Ray Authors. |
| # |
| # Use of this source code is governed by a ISC-style |
| # license that can be found in the LICENSE file or at |
| # https://opensource.org/licenses/ISC |
| # |
| # SPDX-License-Identifier: ISC |
| all: |
| |
| clean: |
| rm -r build |
| |
| build/.touch: |
| mkdir -p build |
| touch build/.touch |
| |
| %.json: %.json5 |
| python3 ${XRAY_UTILS_DIR}/clean_json5.py < $< > $@ |
| |
| CURDIR=$(shell pwd) |
| |
| define output_timing |
| |
| # $(1) - ITER |
| # $(2) - DESIGN_NAME |
| # $(3) - VERILOGS |
| |
| build/$(2)_$(1)/timing_$(2)_$(1).json5: build/.touch runme.tcl ${XRAY_UTILS_DIR}/write_timing_info.tcl $(3) |
| rm -rf build/$(2)_$(1) |
| mkdir -p build/$(2)_$(1) |
| export ITER=$(1) DESIGN_NAME=$(2) VERILOGS="$(3)" && cd build/$(2)_$(1) && \ |
| ${XRAY_VIVADO} -mode batch -source ${CURDIR}/runme.tcl > design_$(2)_$(1)_vivado.log |
| |
| build/timing_$(2)_$(1).xlsx: build/$(2)_$(1)/timing_$(2)_$(1).json ${XRAY_UTILS_DIR}/create_timing_worksheet_db.py |
| python3 ${XRAY_UTILS_DIR}/create_timing_worksheet_db.py \ |
| --timing_json build/$(2)_$(1)/timing_$(2)_$(1).json \ |
| --db_root ${XRAY_FAMILY_DIR} \ |
| --part ${XRAY_PART} \ |
| --output_xlsx build/timing_$(2)_$(1).xlsx |
| |
| build/$(2)_$(1)/design_$(2)_$(1).fasm: build/$(2)_$(1)/timing_$(2)_$(1).json |
| ${XRAY_BIT2FASM} --verbose build/$(2)_$(1)/design_$(2)_$(1).bit > build/$(2)_$(1)/design_$(2)_$(1).fasm |
| |
| $(2)_$(1): build/timing_$(2)_$(1).xlsx build/$(2)_$(1)/design_$(2)_$(1).fasm |
| |
| $(2): $(2)_$(1) |
| |
| .PHONY: $(2) $(2)_$(1) |
| |
| all: $(2)_$(1) |
| |
| endef |
| |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),dff,${CURDIR}/top_dff.v))) |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),cff,${CURDIR}/top_cff.v))) |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),bff,${CURDIR}/top_bff.v))) |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),aff,${CURDIR}/top_aff.v))) |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),dff2,${CURDIR}/top_dff2.v))) |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),dff_inter,${CURDIR}/top_dff_inter.v))) |
| $(foreach ITER,$(shell seq 1 63), $(eval $(call output_timing,$(ITER),dff_slicem,${CURDIR}/top_dff_slicem.v))) |
| $(foreach ITER,20 50 100 1000 10000, $(eval $(call output_timing,$(ITER),fanout,${CURDIR}/top_fanout.v))) |
| $(foreach ITER,0, $(eval $(call output_timing,$(ITER),fanout_ex,${CURDIR}/fanout_ex.v))) |
| $(foreach ITER,0, $(eval $(call output_timing,$(ITER),counter,${CURDIR}/top_counter.v))) |
| $(foreach ITER,$(shell seq 1 3), $(eval $(call output_timing,$(ITER),picorv32, \ |
| $(addprefix ${CURDIR}/, \ |
| picosoc_noflash.v picorv32.v progmem.v basys3_demo.v simpleuart.v)))) |
| |
| .PHONY: all clean |