cvw/sim/vcs/run_vcs

114 lines
3.7 KiB
Plaintext
Raw Normal View History

2024-04-03 17:39:02 +00:00
#!/bin/bash
2024-04-20 21:12:55 +00:00
# VCS Compilation for WALLY
# Divya Kohli, Rose Thompson, David Harris 2024
2024-04-21 05:52:08 +00:00
# Note: VCS produces warning about unsupported Linux Version, but runs successfully
2024-04-20 21:12:55 +00:00
# SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1
2024-04-03 17:39:02 +00:00
2024-05-07 17:41:02 +00:00
# Color Definitions
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
NC='\033[0m' # No Color
# Directories
CFG="${WALLY}/config"
SRC="${WALLY}/src"
TB="${WALLY}/testbench"
2024-04-03 17:39:02 +00:00
# Set CONFIG_VARIANT from the first script argument
CONFIG_VARIANT=${1}
# Set TESTSUITE from the second script argument
TESTSUITE=$2
2024-05-07 17:41:02 +00:00
WKDIR="wkdir/${1}_${2}"
COV="cov/${1}_${2}"
LOGS="logs"
2024-05-08 11:25:03 +00:00
shift 2
PLUSARGS="$*"
2024-05-07 17:41:02 +00:00
clean_logs() {
echo -e "${YELLOW}Cleaning up workspace...${NC}"
rm -rf wkdir logs cov
}
clean_simprofile() {
echo -e "${YELLOW}Cleaning up simprofile_dir...${NC}"
2024-05-08 11:25:03 +00:00
rm -rf simprofile_dir* profileReport*
2024-05-07 17:41:02 +00:00
}
2024-05-08 11:25:03 +00:00
#clean_simprofile
2024-05-07 17:41:02 +00:00
#clean_logs
# Function to create a directory if it does not exist
create_directory() {
local dir=$1 # Local variable for directory name
if [ ! -d "$dir" ]; then
mkdir -p "$dir"
if [ $? -eq 0 ]; then
echo "Directory $dir created successfully."
else
echo "Failed to create directory $dir."
exit 1
fi
2024-05-02 18:52:54 +00:00
else
2024-05-07 17:41:02 +00:00
echo "Directory $dir already exists."
2024-05-02 18:52:54 +00:00
fi
2024-05-07 17:41:02 +00:00
}
# Create or verify WKDIR, COV, and LOGS directories
create_directory "$WKDIR"
create_directory "$COV"
create_directory "$LOGS"
# Ensure the working directory exists
if [ ! -d "$WKDIR" ]; then
echo -e "${YELLOW}Directory $WKDIR does not exist. Creating it now...${NC}"
mkdir -p "$WKDIR" && echo -e "${GREEN}Directory $WKDIR created successfully.${NC}" || {
echo -e "${RED}Failed to create directory $WKDIR.${NC}"
exit 1
}
2024-05-02 18:52:54 +00:00
else
2024-05-07 17:41:02 +00:00
echo -e "${GREEN}Directory $WKDIR already exists.${NC}"
2024-05-02 18:52:54 +00:00
fi
2024-05-07 17:41:02 +00:00
# GUI option handling
GUI=""
if [ "$3" = "gui" ]; then
2024-05-02 18:52:54 +00:00
GUI="-gui"
else
GUI=""
fi
2024-04-20 21:12:55 +00:00
2024-05-07 17:41:02 +00:00
# Collect include directories
2024-04-20 21:12:55 +00:00
INCLUDE_DIRS=$(find ${SRC} -type d | xargs -I {} echo -n "{} ")
2024-05-07 17:41:02 +00:00
INCLUDE_PATH="+incdir+${CFG}/${CONFIG_VARIANT} +incdir+${CFG}/deriv/${CONFIG_VARIANT} +incdir+${CFG}/shared +incdir+../../tests +define+ +incdir+${TB} ${SRC}/cvw.sv +incdir+${SRC}"
2024-04-20 21:12:55 +00:00
2024-05-07 17:41:02 +00:00
# Prepare RTL files avoiding certain paths
RTL_FILES="$INCLUDE_DIRS $(find ${SRC} -name "*.sv" ! -path "${SRC}/generic/clockgater.sv" ! -path "${SRC}/generic/mem/rom1p1r_128x64.sv" ! -path "${SRC}/generic/mem/ram2p1r1wbe_128x64.sv" ! -path "${SRC}/generic/mem/rom1p1r_128x32.sv" ! -path "${SRC}/generic/mem/ram2p1r1wbe_512x64.sv") ${TB}/testbench.sv $(find ${TB}/common -name "*.sv" ! -path "${TB}/common/wallyTracer.sv")"
# Simulation and Coverage Commands
2024-04-03 17:39:02 +00:00
OUTPUT="sim_out"
2024-05-08 11:25:03 +00:00
VCS_CMD="vcs +lint=all,noGCWM,noUI,noSVA-UA,noIDTS,noNS,noULCO,noCAWM-L,noWMIA-L,noSV-PIU,noSTASKW_CO,noSTASKW_CO1,noSTASKW_RMCOF +vcs+vcdpluson -suppress +warn -sverilog +vc -Mupdate -line -full64 -kdb -lca -debug_access+all+reverse -ntb_opts sensitive_dyn +define+SIM_VCS ${INCLUDE_PATH} $RTL_FILES"
SIMV_CMD="./${WKDIR}/$OUTPUT +TEST=${TESTSUITE} ${PLUSARGS}"
2024-05-07 17:41:02 +00:00
COV_FILES="${TB}/coverage/test_pmp_coverage.sv"
COV_OPTIONS="-cm line+cond+branch+fsm+tgl -cm_log ${WKDIR}/coverage.log -cm_dir ${WKDIR}/COVERAGE"
COV_RUN="urg -dir ${WKDIR}/sim_out.vdb/"
2024-04-03 17:39:02 +00:00
# Clean and run simulation with VCS
2024-05-07 17:41:02 +00:00
if [ "$3" = "coverage" ]; then
echo -e "${YELLOW}#### Running VCS Simulation with Coverage ####${NC}"
# Code Coverage.
$VCS_CMD $COV_OPTIONS -o ${WKDIR}/$OUTPUT -Mlib ${WKDIR} -work ${WKDIR} -l "$LOGS/${CONFIG_VARIANT}_${TESTSUITE}.log"
$SIMV_CMD
$COV_RUN
cp -rf urgReport $COV
else
echo -e "${YELLOW}#### Running VCS Simulation ####${NC}"
2024-05-08 11:25:03 +00:00
$VCS_CMD -Mdir=${WKDIR} -o ${WKDIR}/$OUTPUT -work ${WKDIR} -Mlib ${WKDIR} -l "$LOGS/${CONFIG_VARIANT}_${TESTSUITE}.log"
$SIMV_CMD
2024-05-07 17:41:02 +00:00
fi