mirror of https://github.com/openXC7/prjxray.git
Fixes for zynq7 and PLL fuzzing.
Signed-off-by: Keith Rothman <537074+litghost@users.noreply.github.com>
This commit is contained in:
parent
a7f5a305b9
commit
b77c47b155
|
|
@ -18,6 +18,7 @@ TILEGRID_TDB_DEPENDENCIES += monitor_int/build/segbits_tilegrid.tdb
|
||||||
TILEGRID_TDB_DEPENDENCIES += clk_hrow/build/segbits_tilegrid.tdb
|
TILEGRID_TDB_DEPENDENCIES += clk_hrow/build/segbits_tilegrid.tdb
|
||||||
TILEGRID_TDB_DEPENDENCIES += clk_bufg/build/segbits_tilegrid.tdb
|
TILEGRID_TDB_DEPENDENCIES += clk_bufg/build/segbits_tilegrid.tdb
|
||||||
TILEGRID_TDB_DEPENDENCIES += hclk_cmt/build/segbits_tilegrid.tdb
|
TILEGRID_TDB_DEPENDENCIES += hclk_cmt/build/segbits_tilegrid.tdb
|
||||||
|
TILEGRID_TDB_DEPENDENCIES += pll/build/segbits_tilegrid.tdb
|
||||||
GENERATE_FULL_ARGS=
|
GENERATE_FULL_ARGS=
|
||||||
|
|
||||||
ifeq (${XRAY_DATABASE}, zynq7)
|
ifeq (${XRAY_DATABASE}, zynq7)
|
||||||
|
|
@ -25,7 +26,6 @@ ifeq (${XRAY_DATABASE}, zynq7)
|
||||||
TILEGRID_TDB_DEPENDENCIES += ps7_int/build/segbits_tilegrid.tdb
|
TILEGRID_TDB_DEPENDENCIES += ps7_int/build/segbits_tilegrid.tdb
|
||||||
else
|
else
|
||||||
# Artix7/Kintex7 only
|
# Artix7/Kintex7 only
|
||||||
TILEGRID_TDB_DEPENDENCIES += pll/build/segbits_tilegrid.tdb
|
|
||||||
TILEGRID_TDB_DEPENDENCIES += mmcm/build/segbits_tilegrid.tdb
|
TILEGRID_TDB_DEPENDENCIES += mmcm/build/segbits_tilegrid.tdb
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -5,8 +5,7 @@ database: build/segbits_cmt_top_upper_t.db
|
||||||
|
|
||||||
build/segbits_cmt_top_upper_t.rdb: $(SPECIMENS_OK)
|
build/segbits_cmt_top_upper_t.rdb: $(SPECIMENS_OK)
|
||||||
${XRAY_SEGMATCH} -c 150 -o build/segbits_cmt_top_upper_t.rdb \
|
${XRAY_SEGMATCH} -c 150 -o build/segbits_cmt_top_upper_t.rdb \
|
||||||
$(addsuffix /segdata_cmt_top_r_upper_t.txt,$(SPECIMENS)) \
|
$(shell find ${FUZDIR} -name "segdata_cmt_top_*_upper_t.txt")
|
||||||
$(addsuffix /segdata_cmt_top_l_upper_t.txt,$(SPECIMENS))
|
|
||||||
|
|
||||||
build/segbits_cmt_top_upper_t.db: build/segbits_cmt_top_upper_t.rdb write_pll_reg.py
|
build/segbits_cmt_top_upper_t.db: build/segbits_cmt_top_upper_t.rdb write_pll_reg.py
|
||||||
python3 write_pll_reg.py \
|
python3 write_pll_reg.py \
|
||||||
|
|
|
||||||
|
|
@ -10,8 +10,11 @@ set_property BITSTREAM.GENERAL.PERFRAMECRC YES [current_design]
|
||||||
|
|
||||||
create_clock -period 10.00 [get_ports clk]
|
create_clock -period 10.00 [get_ports clk]
|
||||||
|
|
||||||
|
set net [get_nets clk_IBUF]
|
||||||
|
if { [llength $net] > 0 } {
|
||||||
|
set_property CLOCK_DEDICATED_ROUTE FALSE [get_nets clk_IBUF]
|
||||||
|
}
|
||||||
|
|
||||||
set_property CLOCK_DEDICATED_ROUTE FALSE [get_nets clk_IBUF]
|
|
||||||
# Disable MMCM frequency etc sanity checks
|
# Disable MMCM frequency etc sanity checks
|
||||||
set_property IS_ENABLED 0 [get_drc_checks {PDRC-29}]
|
set_property IS_ENABLED 0 [get_drc_checks {PDRC-29}]
|
||||||
set_property IS_ENABLED 0 [get_drc_checks {PDRC-30}]
|
set_property IS_ENABLED 0 [get_drc_checks {PDRC-30}]
|
||||||
|
|
|
||||||
|
|
@ -23,7 +23,12 @@ def main():
|
||||||
f = open('params.jl', 'w')
|
f = open('params.jl', 'w')
|
||||||
f.write('module,loc,params\n')
|
f.write('module,loc,params\n')
|
||||||
|
|
||||||
print('module top(input clk);')
|
print(
|
||||||
|
"""module top(input clk);
|
||||||
|
|
||||||
|
(* KEEP, DONT_TOUCH *)
|
||||||
|
LUT1 dummy();
|
||||||
|
""")
|
||||||
|
|
||||||
for site in sorted(gen_sites()):
|
for site in sorted(gen_sites()):
|
||||||
params = {
|
params = {
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,13 @@
|
||||||
export FUZDIR=$(shell pwd)
|
export FUZDIR=$(shell pwd)
|
||||||
PIP_TYPE?=cmt_top
|
PIP_TYPE?=cmt_top
|
||||||
PIPLIST_TCL=$(FUZDIR)/cmt_top_upper_t.tcl
|
PIPLIST_TCL=$(FUZDIR)/cmt_top_upper_t.tcl
|
||||||
TODO_RE=".*\.CMT_TOP_R_UPPER_T_PLLE2_CLK_[^_]+_INT"
|
TODO_RE=".*\.CMT_TOP_[LR]_UPPER_T_PLLE2_CLK_[^_]+_INT"
|
||||||
|
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
MAKETODO_FLAGS=--sides "r_upper_t,l_upper_t" --pip-type ${PIP_TYPE} --seg-type cmt_top --re $(TODO_RE)
|
MAKETODO_FLAGS=--sides "r_upper_t,l_upper_t" --pip-type ${PIP_TYPE} --seg-type cmt_top --re $(TODO_RE)
|
||||||
|
else
|
||||||
|
MAKETODO_FLAGS=--sides "l_upper_t" --pip-type ${PIP_TYPE} --seg-type cmt_top --re $(TODO_RE)
|
||||||
|
endif
|
||||||
N = 50
|
N = 50
|
||||||
|
|
||||||
A_PIPLIST=cmt_top_l_upper_t.txt
|
A_PIPLIST=cmt_top_l_upper_t.txt
|
||||||
|
|
@ -14,38 +18,55 @@ build/segbits_cmt_top_l_upper_t.rdb: $(SPECIMENS_OK)
|
||||||
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_cmt_top_l_upper_t.rdb \
|
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_cmt_top_l_upper_t.rdb \
|
||||||
$(shell find build -name segdata_cmt_top_l_upper_t.txt)
|
$(shell find build -name segdata_cmt_top_l_upper_t.txt)
|
||||||
|
|
||||||
|
RDBS = build/segbits_cmt_top_l_upper_t.rdb
|
||||||
|
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
|
# Target Zynq7 part has no CMT_TOP_R_UPPER_T
|
||||||
build/segbits_cmt_top_r_upper_t.rdb: $(SPECIMENS_OK)
|
build/segbits_cmt_top_r_upper_t.rdb: $(SPECIMENS_OK)
|
||||||
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_cmt_top_r_upper_t.rdb \
|
${XRAY_SEGMATCH} ${SEGMATCH_FLAGS} -o build/segbits_cmt_top_r_upper_t.rdb \
|
||||||
$(shell find build -name segdata_cmt_top_r_upper_t.txt)
|
$(shell find build -name segdata_cmt_top_r_upper_t.txt)
|
||||||
|
|
||||||
database: build/segbits_cmt_top_l_upper_t.rdb build/segbits_cmt_top_r_upper_t.rdb
|
RDBS += build/segbits_cmt_top_r_upper_t.rdb
|
||||||
|
endif
|
||||||
|
|
||||||
|
database: ${RDBS}
|
||||||
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
|
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
|
||||||
--seg-fn-in build/segbits_cmt_top_l_upper_t.rdb \
|
--seg-fn-in build/segbits_cmt_top_l_upper_t.rdb \
|
||||||
--seg-fn-out build/segbits_cmt_top_l_upper_t.db
|
--seg-fn-out build/segbits_cmt_top_l_upper_t.db
|
||||||
|
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
|
${XRAY_DBFIXUP} --db-root build --zero-db bits.dbf \
|
||||||
--seg-fn-in build/segbits_cmt_top_r_upper_t.rdb \
|
--seg-fn-in build/segbits_cmt_top_r_upper_t.rdb \
|
||||||
--seg-fn-out build/segbits_cmt_top_r_upper_t.db
|
--seg-fn-out build/segbits_cmt_top_r_upper_t.db
|
||||||
|
endif
|
||||||
|
|
||||||
# Keep a copy to track iter progress
|
# Keep a copy to track iter progress
|
||||||
cp build/segbits_cmt_top_l_upper_t.rdb build/$(ITER)/segbits_cmt_top_l_upper_t.rdb
|
cp build/segbits_cmt_top_l_upper_t.rdb build/$(ITER)/segbits_cmt_top_l_upper_t.rdb
|
||||||
cp build/segbits_cmt_top_l_upper_t.db build/$(ITER)/segbits_cmt_top_l_upper_t.db
|
cp build/segbits_cmt_top_l_upper_t.db build/$(ITER)/segbits_cmt_top_l_upper_t.db
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
cp build/segbits_cmt_top_r_upper_t.rdb build/$(ITER)/segbits_cmt_top_r_upper_t.rdb
|
cp build/segbits_cmt_top_r_upper_t.rdb build/$(ITER)/segbits_cmt_top_r_upper_t.rdb
|
||||||
cp build/segbits_cmt_top_r_upper_t.db build/$(ITER)/segbits_cmt_top_r_upper_t.db
|
cp build/segbits_cmt_top_r_upper_t.db build/$(ITER)/segbits_cmt_top_r_upper_t.db
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
${XRAY_MASKMERGE} build/mask_cmt_top_l_upper_t.db \
|
${XRAY_MASKMERGE} build/mask_cmt_top_l_upper_t.db \
|
||||||
$(shell find build -name segdata_cmt_top_l_upper_t.txt)
|
$(shell find build -name segdata_cmt_top_l_upper_t.txt)
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
${XRAY_MASKMERGE} build/mask_cmt_top_r_upper_t.db \
|
${XRAY_MASKMERGE} build/mask_cmt_top_r_upper_t.db \
|
||||||
$(shell find build -name segdata_cmt_top_r_upper_t.txt)
|
$(shell find build -name segdata_cmt_top_r_upper_t.txt)
|
||||||
|
endif
|
||||||
|
|
||||||
# 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/database/${XRAY_DATABASE}
|
||||||
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} cmt_top_l_upper_t build/segbits_cmt_top_l_upper_t.db
|
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} cmt_top_l_upper_t build/segbits_cmt_top_l_upper_t.db
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} cmt_top_r_upper_t build/segbits_cmt_top_r_upper_t.db
|
XRAY_DATABASE_DIR=${FUZDIR}/build/database ${XRAY_MERGEDB} cmt_top_r_upper_t build/segbits_cmt_top_r_upper_t.db
|
||||||
|
endif
|
||||||
|
|
||||||
pushdb: database
|
pushdb: database
|
||||||
${XRAY_MERGEDB} cmt_top_l_upper_t build/segbits_cmt_top_l_upper_t.db
|
${XRAY_MERGEDB} cmt_top_l_upper_t build/segbits_cmt_top_l_upper_t.db
|
||||||
|
ifneq (${XRAY_DATABASE}, zynq7)
|
||||||
${XRAY_MERGEDB} cmt_top_r_upper_t build/segbits_cmt_top_r_upper_t.db
|
${XRAY_MERGEDB} cmt_top_r_upper_t build/segbits_cmt_top_r_upper_t.db
|
||||||
|
endif
|
||||||
|
|
||||||
.PHONY: database pushdb
|
.PHONY: database pushdb
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue