|  | # 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 | 
|  | SYNTH ?= vivado | 
|  | YOSYS = $(XRAY_DIR)/third_party/yosys/yosys | 
|  | PART = xc7a35tcsg324-1 | 
|  | BIT2FASM_ARGS = --part "$(XRAY_DIR)/database/artix7/$(PART)" --verbose | 
|  |  | 
|  | VERILOG_FILES = $(wildcard *.v) | 
|  | FASM_TARGETS = $(VERILOG_FILES:.v=.fasm) | 
|  | SEGPRINT_TARGETS = $(VERILOG_FILES:.v=.segprint.log) | 
|  |  | 
|  | all: $(FASM_TARGETS) $(SEGPRINT_TARGETS) | 
|  |  | 
|  | clean: | 
|  | @find . -name "build-par.*" | xargs rm -rf | 
|  | @find . -name "build-syn.*" | xargs rm -rf | 
|  | @rm -f *.edif | 
|  | @rm -f *.bit | 
|  | @rm -f *.bin | 
|  | @rm -f *.bits | 
|  | @rm -f *.fasm | 
|  | @rm -f *.log | 
|  | @rm -f *.dcp | 
|  |  | 
|  | help: | 
|  | @echo "Usage: make all [SYNTH=<vivado/yosys>]" | 
|  |  | 
|  | .PHONY: all clean help | 
|  |  | 
|  | $(YOSYS): | 
|  | cd $(XRAY_DIR)/third_party/yosys && make config-gcc && make -j$(shell nproc) | 
|  |  | 
|  | ifeq ($(SYNTH), yosys) | 
|  | %.edif: %.v $(YOSYS) | 
|  | $(YOSYS) -p "read_verilog $< ; synth_xilinx -flatten -nosrl; write_edif -pvector bra -attrprop $@"  -l $@.log | 
|  |  | 
|  | else ifeq ($(SYNTH), vivado) | 
|  | %.edif: %.v $(YOSYS) | 
|  | mkdir -p build-syn.$(basename $@) | 
|  | cd build-syn.$(basename $@) && env PROJECT_NAME=$(basename $@) $(XRAY_VIVADO) -mode batch -source ../syn.tcl -nojournal -log ../$@.log | 
|  | rm -rf *.backup.log | 
|  |  | 
|  | endif | 
|  |  | 
|  | %.bit: %.edif par.tcl | 
|  | mkdir -p build-par.$(basename $@) | 
|  | cd build-par.$(basename $@) && env PROJECT_NAME=$(basename $@) $(XRAY_VIVADO) -mode batch -source ../par.tcl -nojournal -log ../$@.log | 
|  | rm -rf *.backup.log | 
|  |  | 
|  | %.fasm: %.bit | 
|  | PYTHONPATH="$(XRAY_DIR):$(XRAY_DIR)/utils:$(XRAY_DIR)/third_party/fasm" \ | 
|  | PATH="$(XRAY_DIR)/build/tools:$(PATH)" \ | 
|  | $(XRAY_BIT2FASM) $(BIT2FASM_ARGS) \ | 
|  | $< >$@ \ | 
|  | || (rm -f $@ && exit 1) | 
|  |  | 
|  | %.unique.fasm: %.fasm | 
|  | @sort -u $< >$@ | 
|  |  | 
|  | %.bits: %.bit | 
|  | $(XRAY_BITREAD) -part_file $(XRAY_DIR)/database/artix7/$(PART).yaml -o $@ -z -y $< | 
|  |  | 
|  | %.segprint.log: %.bits | 
|  | $(XRAY_SEGPRINT) -z -D -b $< > $@ |