mirror of https://github.com/openXC7/prjxray.git
65 lines
2.3 KiB
Makefile
65 lines
2.3 KiB
Makefile
export FUZDIR=$(shell pwd)
|
|
PIP_TYPE?=clk_hrow
|
|
PIPLIST_TCL=$(FUZDIR)/clk_hrow_pip_list.tcl
|
|
ifeq (${XRAY_PART}, xc7z010clg400-1)
|
|
# xc7z010clg400-1 is missing some side clock connections, so these bits cannot
|
|
# be documented.
|
|
TODO_RE="[^\.]+\.CLK_HROW_CK_MUX_OUT_[LR][0-9]+\.CLK_HROW_.*[KR_][0-9]+"
|
|
else
|
|
TODO_RE="[^\.]+\.CLK_HROW_CK_MUX_OUT_"
|
|
endif
|
|
|
|
MAKETODO_FLAGS=--no-l --pip-type clk_hrow_bot --seg-type clk_hrow_bot --re $(TODO_RE)
|
|
N = 50
|
|
|
|
# These PIPs all appear to be either a 1 bit solutions.
|
|
SEGMATCH_FLAGS=-c 1
|
|
SPECIMENS_DEPS=build/cmt_regions.csv
|
|
A_PIPLIST=clk_hrow_bot_r.txt
|
|
|
|
include ../pip_loop.mk
|
|
|
|
database: build/segbits_clk_hrow.db
|
|
|
|
build/cmt_regions.csv: output_cmt.tcl
|
|
mkdir -p build
|
|
cd build/ && ${XRAY_VIVADO} -mode batch -source ${FUZDIR}/output_cmt.tcl
|
|
|
|
build/segbits_clk_hrow.rdb: $(SPECIMENS_OK)
|
|
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_clk_hrow.rdb \
|
|
$(shell find build -name segdata_clk_hrow_top_r.txt) \
|
|
$(shell find build -name segdata_clk_hrow_bot_r.txt)
|
|
|
|
build/segbits_clk_hrow.db: build/segbits_clk_hrow.rdb $(XRAY_FUZZERS_DIR)/piplist/build/clk_hrow_bot_r.txt
|
|
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
|
|
--seg-fn-in build/segbits_clk_hrow.rdb \
|
|
--seg-fn-out build/segbits_clk_hrow_rc.db
|
|
|
|
# Convert row/column into PIP definition.
|
|
python3 merge_clk_entries.py \
|
|
build/segbits_clk_hrow_rc.db \
|
|
$(XRAY_FUZZERS_DIR)/piplist/build/clk_hrow_bot_r.txt \
|
|
build/segbits_clk_hrow.db
|
|
|
|
# Keep a copy to track iter progress
|
|
cp build/segbits_clk_hrow.rdb build/$(ITER)/segbits_clk_hrow.rdb
|
|
cp build/segbits_clk_hrow_rc.db build/$(ITER)/segbits_clk_hrow_rc.db
|
|
|
|
|
|
${XRAY_MASKMERGE} build/mask_clk_hrow.db \
|
|
$(shell find build -name segdata_clk_hrow_top_r.txt) \
|
|
$(shell find build -name segdata_clk_hrow_bot_r.txt)
|
|
|
|
# Clobber existing .db to eliminate potential conflicts
|
|
cp ${XRAY_DATABASE_DIR}/${XRAY_DATABASE}/segbits*.db build/database/${XRAY_DATABASE}
|
|
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} clk_hrow_bot_r build/segbits_clk_hrow.db
|
|
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} clk_hrow_top_r build/segbits_clk_hrow.db
|
|
|
|
pushdb: database
|
|
${XRAY_MERGEDB} clk_hrow_bot_r build/segbits_clk_hrow.db
|
|
${XRAY_MERGEDB} clk_hrow_top_r build/segbits_clk_hrow.db
|
|
${XRAY_MERGEDB} mask_clk_hrow_bot_r build/mask_clk_hrow.db
|
|
${XRAY_MERGEDB} mask_clk_hrow_top_r build/mask_clk_hrow.db
|
|
|
|
.PHONY: database pushdb
|