# 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