mirror of https://github.com/openXC7/prjxray.git
065-gtp-common-pips: enable fuzzer in makefile
Signed-off-by: Alessandro Comodi <acomodi@antmicro.com>
This commit is contained in:
parent
913a6ece40
commit
618e170875
|
|
@ -6,51 +6,53 @@
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: ISC
|
# SPDX-License-Identifier: ISC
|
||||||
export FUZDIR=$(shell pwd)
|
export FUZDIR=$(shell pwd)
|
||||||
PIP_TYPE?=gtp_common
|
PIP_TYPE?=gtp_common_${XRAY_PART}
|
||||||
|
SEG_TYPE?=gtp_common
|
||||||
PIPLIST_TCL=$(FUZDIR)/gtp_common_pip_list.tcl
|
PIPLIST_TCL=$(FUZDIR)/gtp_common_pip_list.tcl
|
||||||
|
|
||||||
|
BUILD_DIR = ${FUZDIR}/build_${XRAY_PART}
|
||||||
|
RUN_OK = run.${XRAY_PART}.ok
|
||||||
|
|
||||||
TODO_RE=".*"
|
TODO_RE=".*"
|
||||||
|
|
||||||
MAKETODO_FLAGS=--pip-type ${PIP_TYPE} --seg-type $(PIP_TYPE) --re $(TODO_RE) --sides ""
|
MAKETODO_FLAGS=--pip-type ${PIP_TYPE} --seg-type $(SEG_TYPE) --re $(TODO_RE) --sides ""
|
||||||
N = 20
|
N = 60
|
||||||
|
|
||||||
SEGMATCH_FLAGS=-c 2
|
SEGMATCH_FLAGS=-c 2
|
||||||
SPECIMENS_DEPS=build/cmt_regions.csv
|
SPECIMENS_DEPS=$(BUILD_DIR)/cmt_regions.csv
|
||||||
A_PIPLIST=gtp_common.txt
|
A_PIPLIST=gtp_common_${XRAY_PART}.txt
|
||||||
|
|
||||||
include ../pip_loop.mk
|
include ../pip_loop.mk
|
||||||
|
|
||||||
build/segbits_gtp_common.rdb: $(SPECIMENS_OK)
|
$(BUILD_DIR)/segbits_gtp_common.rdb: $(SPECIMENS_OK)
|
||||||
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_gtp_common.rdb \
|
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o $(BUILD_DIR)/segbits_gtp_common.rdb \
|
||||||
$(shell find build -name segdata_gtp_common*.txt)
|
$(shell find $(BUILD_DIR) -name segdata_gtp_common*.txt)
|
||||||
|
|
||||||
RDBS = build/segbits_gtp_common.rdb
|
RDBS = $(BUILD_DIR)/segbits_gtp_common.rdb
|
||||||
|
|
||||||
database: ${RDBS}
|
database: ${RDBS}
|
||||||
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
|
${XRAY_DBFIXUP} --db-root $(BUILD_DIR) --zero-db bits.dbf \
|
||||||
--seg-fn-in build/segbits_gtp_common.rdb \
|
--seg-fn-in $(BUILD_DIR)/segbits_gtp_common.rdb \
|
||||||
--seg-fn-out build/segbits_gtp_common.db
|
--seg-fn-out $(BUILD_DIR)/segbits_gtp_common.db
|
||||||
|
|
||||||
# Keep a copy to track iter progress
|
# Keep a copy to track iter progress
|
||||||
cp build/segbits_gtp_common.rdb build/$(ITER)/segbits_gtp_common.rdb
|
cp $(BUILD_DIR)/segbits_gtp_common.rdb $(BUILD_DIR)/$(ITER)/segbits_gtp_common.rdb
|
||||||
cp build/segbits_gtp_common.db build/$(ITER)/segbits_gtp_common.db
|
cp $(BUILD_DIR)/segbits_gtp_common.db $(BUILD_DIR)/$(ITER)/segbits_gtp_common.db
|
||||||
|
|
||||||
# Clobber existing .db to eliminate potential conflicts
|
# Clobber existing .db to eliminate potential conflicts
|
||||||
cp ${XRAY_DATABASE_DIR}/${XRAY_DATABASE}/segbits*.db build/database/${XRAY_DATABASE}
|
cp ${XRAY_DATABASE_DIR}/${XRAY_DATABASE}/segbits*.db $(BUILD_DIR)/database/${XRAY_DATABASE}
|
||||||
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} gtp_common build/segbits_gtp_common.db
|
XRAY_DATABASE_DIR=$(BUILD_DIR)/database ${XRAY_MERGEDB} gtp_common_mid_left $(BUILD_DIR)/segbits_gtp_common.db
|
||||||
|
XRAY_DATABASE_DIR=$(BUILD_DIR)/database ${XRAY_MERGEDB} gtp_common_mid_right $(BUILD_DIR)/segbits_gtp_common.db
|
||||||
|
|
||||||
build/cmt_regions.csv: output_cmt.tcl
|
$(BUILD_DIR)/cmt_regions.csv: output_cmt.tcl
|
||||||
mkdir -p build
|
mkdir -p $(BUILD_DIR)
|
||||||
cd build/ && ${XRAY_VIVADO} -mode batch -source ${FUZDIR}/output_cmt.tcl
|
cd $(BUILD_DIR)/ && ${XRAY_VIVADO} -mode batch -source ${FUZDIR}/output_cmt.tcl
|
||||||
|
|
||||||
|
clean_all:
|
||||||
|
rm -rf build_* run.*.ok
|
||||||
|
|
||||||
pushdb: database
|
pushdb: database
|
||||||
${XRAY_MERGEDB} gtp_common_mid_left build/segbits_gtp_common.db
|
${XRAY_MERGEDB} gtp_common_mid_left $(BUILD_DIR)/segbits_gtp_common.db
|
||||||
${XRAY_MERGEDB} gtp_common_mid_right build/segbits_gtp_common.db
|
${XRAY_MERGEDB} gtp_common_mid_right $(BUILD_DIR)/segbits_gtp_common.db
|
||||||
|
|
||||||
run:
|
.PHONY: database pushdb run clean
|
||||||
$(MAKE) clean
|
|
||||||
+$(FUZDIR)/../int_loop.sh --check-args "--zero-entries --timeout-iters 10"
|
|
||||||
touch run.${XRAY_PART}.ok
|
|
||||||
|
|
||||||
.PHONY: database pushdb run
|
|
||||||
|
|
|
||||||
|
|
@ -27,8 +27,9 @@ def bitfilter(frame, word):
|
||||||
|
|
||||||
|
|
||||||
def read_pip_data(pipfile, pipdata, tile_ports):
|
def read_pip_data(pipfile, pipdata, tile_ports):
|
||||||
|
part = os.getenv('XRAY_PART')
|
||||||
with open(os.path.join(os.getenv('FUZDIR'), '..', 'piplist', 'build',
|
with open(os.path.join(os.getenv('FUZDIR'), '..', 'piplist', 'build',
|
||||||
'gtp_common', pipfile)) as f:
|
'gtp_common_{}'.format(part), pipfile)) as f:
|
||||||
for l in f:
|
for l in f:
|
||||||
tile_type, dst, src = l.strip().split('.')
|
tile_type, dst, src = l.strip().split('.')
|
||||||
if tile_type not in pipdata:
|
if tile_type not in pipdata:
|
||||||
|
|
@ -48,7 +49,8 @@ def main():
|
||||||
ignpip = set()
|
ignpip = set()
|
||||||
tile_ports = {}
|
tile_ports = {}
|
||||||
|
|
||||||
read_pip_data('gtp_common.txt', pipdata, tile_ports)
|
part = os.getenv('XRAY_PART')
|
||||||
|
read_pip_data('gtp_common_{}.txt'.format(part), pipdata, tile_ports)
|
||||||
|
|
||||||
print("Loading tags from design.txt.")
|
print("Loading tags from design.txt.")
|
||||||
with open("design.txt", "r") as f:
|
with open("design.txt", "r") as f:
|
||||||
|
|
|
||||||
|
|
@ -46,4 +46,4 @@ create_project -force -part $::env(XRAY_PART) design design
|
||||||
set_property design_mode PinPlanning [current_fileset]
|
set_property design_mode PinPlanning [current_fileset]
|
||||||
open_io_design -name io_1
|
open_io_design -name io_1
|
||||||
|
|
||||||
print_tile_pips GTP_COMMON_MID_LEFT gtp_common.txt
|
print_tile_pips GTP_COMMON_MID_LEFT gtp_common_$::env(XRAY_PART).txt
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,10 @@ from prjxray.db import Database
|
||||||
|
|
||||||
def read_site_to_cmt():
|
def read_site_to_cmt():
|
||||||
""" Yields clock sources and which CMT they route within. """
|
""" Yields clock sources and which CMT they route within. """
|
||||||
with open(os.path.join(os.getenv('FUZDIR'), 'build',
|
fuzdir = os.getenv('FUZDIR')
|
||||||
|
part = os.getenv('XRAY_PART')
|
||||||
|
|
||||||
|
with open(os.path.join(fuzdir, 'build_{}'.format(part),
|
||||||
'cmt_regions.csv')) as f:
|
'cmt_regions.csv')) as f:
|
||||||
for l in f:
|
for l in f:
|
||||||
site, cmt = l.strip().split(',')
|
site, cmt = l.strip().split(',')
|
||||||
|
|
|
||||||
|
|
@ -160,6 +160,7 @@ ifeq ($(XRAY_DATABASE),artix7)
|
||||||
$(eval $(call fuzzer,061-pcie-conf,005-tilegrid,all))
|
$(eval $(call fuzzer,061-pcie-conf,005-tilegrid,all))
|
||||||
$(eval $(call fuzzer,063-gtp-common-conf,005-tilegrid,part))
|
$(eval $(call fuzzer,063-gtp-common-conf,005-tilegrid,part))
|
||||||
$(eval $(call fuzzer,064-gtp-channel-conf,005-tilegrid,part))
|
$(eval $(call fuzzer,064-gtp-channel-conf,005-tilegrid,part))
|
||||||
|
$(eval $(call fuzzer,065-gtp-common-pips,005-tilegrid,part))
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue