# Copyright 2024 RapidStream Design Automation, Inc.
# All Rights Reserved.

TARGET=hw
# TARGET=hw_emu
# DEBUG=-g

TOP=indexer_top
XO=/scratch/oswaldhe/vqdsa/indexer_top.xo
INI_CONNECTIVITY_CONFIG=/scratch/oswaldhe/vqdsa/hbm_config.ini
TARGET_FREQUENCY=300
PLATFORM=xilinx_u55c_gen3x16_xdma_3_202210_1
REMOTE_IP_CACHE=/var/tmp/oswaldhe/remote_ip_cache
PLACEMENT_STRATEGY=Explore
STRATEGY=Explore

OUTPUT_DIR="$(pwd)/vitis_run_${TARGET}"

MAX_SYNTH_JOBS=16


v++ ${DEBUG} \
  --link \
  --kernel ${TOP} \
  --platform ${PLATFORM} \
  --target ${TARGET} \
  --report_level 2 \
  --temp_dir "${OUTPUT_DIR}/${TOP}_${PLATFORM}.temp" \
  --optimize 3 \
  --connectivity.nk ${TOP}:1:${TOP} \
  --save-temps \
  "${XO}" \
  --vivado.synth.jobs ${MAX_SYNTH_JOBS} \
--vivado.prop=run.impl_1.STEPS.PHYS_OPT_DESIGN.IS_ENABLED=1 \
  --vivado.prop=run.impl_1.STEPS.OPT_DESIGN.ARGS.DIRECTIVE=$STRATEGY \
  --vivado.prop=run.impl_1.STEPS.PLACE_DESIGN.ARGS.DIRECTIVE=$PLACEMENT_STRATEGY \
  --vivado.prop=run.impl_1.STEPS.ROUTE_DESIGN.ARGS.DIRECTIVE=$STRATEGY \
  --config "${INI_CONNECTIVITY_CONFIG}" \
  --remote_ip_cache ${REMOTE_IP_CACHE} \
--output "${OUTPUT_DIR}/${TOP}_${PLATFORM}.xclbin" \
  --kernel_frequency ${TARGET_FREQUENCY} \


exit_code=$?

exit $exit_code