blob: 3d043448f6f44b7d8cabdf417c25b3af6e26e42f [file] [log] [blame]
# Copyright (C) 2017-2022 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
export FUZDIR=$(shell pwd)
PIP_TYPE?=hclk_ioi
PIPLIST_TCL=$(FUZDIR)/hclk_ioi_pip_list.tcl
TODO_RE=".*"
# FIXME Modify fuzzer to solve PIPs that drive the BUFIO and BUFR from ILOGIC clock or through the IOI tile.
EXCLUDE_RE=".*\.HCLK_IOI_((I2IOCLK)|(IDELAYCTRL))"
MAKETODO_FLAGS= --sides "" --pip-type ${PIP_TYPE} --seg-type ${PIP_TYPE} --re $(TODO_RE) --exclude-re $(EXCLUDE_RE)
N = 499
SEGMATCH_FLAGS=-c 4 -m 4 -M 4
SPECIMENS_DEPS=build/cmt_regions.csv
A_PIPLIST=hclk_ioi.txt
include ../pip_loop.mk
build/segbits_hclk_ioi.rdb: $(SPECIMENS_OK)
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_hclk_ioi.rdb \
$(shell find build -name segdata_hclk_ioi.txt)
build/segbits_hclk_ioi.db: build/segbits_hclk_ioi.rdb
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
--seg-fn-in build/segbits_hclk_ioi.rdb \
--seg-fn-out build/segbits_hclk_ioi.db
# Keep a copy to track iter progress
cp build/segbits_hclk_ioi.rdb build/$(ITER)/segbits_hclk_ioi.rdb
${XRAY_MASKMERGE} build/mask_hclk_ioi.db \
$(shell find build -name segdata_hclk_ioi.txt)
database: build/segbits_hclk_ioi.db
# 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} hclk_ioi build/segbits_hclk_ioi.db
build/cmt_regions.csv: output_cmt.tcl
mkdir -p build
cd build/ && ${XRAY_VIVADO} -mode batch -source ${FUZDIR}/output_cmt.tcl
pushdb: database
${XRAY_MERGEDB} hclk_ioi build/segbits_hclk_ioi.db
${XRAY_MERGEDB} mask_hclk_ioi build/mask_hclk_ioi.db
.PHONY: database pushdb