mirror of
https://github.com/openhwgroup/cvw
synced 2025-01-23 21:14:37 +00:00
70 lines
2.5 KiB
Bash
Executable File
70 lines
2.5 KiB
Bash
Executable File
#!/bin/bash
|
|
# this script is used to run regression inside the Dockerfile.regression
|
|
# of course, you can run it in the current environment as soon as
|
|
# - RISCV is defined
|
|
# - QUESTA is defined
|
|
# declare with empty string: export ABC=
|
|
|
|
# Options:
|
|
# - CVW_GIT: git clone address, only main branch supported
|
|
# - CLEAN_CVW: declared with empty string to clone
|
|
# - BUILD_RISCOF: declared with empty string to rebuild RISCOF
|
|
# - RUN_QUESTA: declared with empty string to run vsim to check
|
|
|
|
# now only main branch is supported
|
|
if [ -z "${CVW_GIT}" ]; then
|
|
echo "No CVW_GIT is provided"
|
|
export CVW_GIT="https://github.com/openhwgroup/cvw"
|
|
else
|
|
echo "Using customized CVW_GIT: ${CVW_GIT}"
|
|
fi
|
|
|
|
git config --global http.version HTTP/1.1
|
|
|
|
# if cvw is not available or CLEAN_CVW(empty string) is defined
|
|
if [[ ! -f "/home/${USERNAME}/cvw/setup.sh" ]] || [[ -z "${CLEAN_CVW-x}" ]]; then
|
|
cd /home/${USERNAME} && rm -rf /home/${USERNAME}/cvw
|
|
git clone --recurse-submodules ${CVW_GIT} /home/${USERNAME}/cvw
|
|
# if failed to clone submodules for some reason, please run `git submodule update`
|
|
fi
|
|
|
|
# Preset Environment Variable
|
|
export PATH="${RISCV}/bin:${PATH}"
|
|
export CVW_HOME="/home/${USERNAME}/cvw"
|
|
export QUESTA="/cad/mentor/questa_sim-xxxx.x_x"
|
|
export PATH="${QUESTA}/questasim/bin:${PATH}"
|
|
|
|
# cd /home/${USERNAME}/cvw && chmod +x ./setup.sh && ./setup.sh
|
|
chmod +x ${CVW_HOME}/setup.sh && source ${CVW_HOME}/setup.sh
|
|
chmod +x ${CVW_HOME}/site-setup.sh && source ${CVW_HOME}/site-setup.sh
|
|
|
|
# Overwriting
|
|
export QUESTAPATH=/cad/mentor/questa_sim-xxxx.x_x/questasim/bin
|
|
|
|
# # if you are making it alone, it works
|
|
# make
|
|
|
|
cd ${CVW_HOME}
|
|
# build it only if BUILD_RISCOF is defined with empty string
|
|
if [[ -z "${BUILD_RISCOF-x}" ]]; then
|
|
make install && make riscof && make testfloat
|
|
fi
|
|
|
|
if [[ -z "${RUN_QUESTA-x}" ]] ; then
|
|
if [ ! -f "${QUESTA}/questasim/bin/vsim" ]; then
|
|
echo "Cannot find vsim with ${QUESTA}/questasim/bin/vsim"
|
|
else
|
|
# cd sim && ./regression-wally 2>&1 > ./regression_questa.out && cd ..
|
|
# make verify
|
|
regression-wally
|
|
fi
|
|
fi
|
|
|
|
make coverage
|
|
make benchmarks
|
|
|
|
if [[ ! NO_VERILATOR -eq 1 ]]; then
|
|
cd ${CVW_HOME}/sim/verilator && verilator -GTEST="\"arch64i\"" -DVERILATOR=1 --timescale "1ns/1ns" --timing --binary --top-module testbench -I${CVW_HOME}/config/shared -I${CVW_HOME}/config/rv64gc ${CVW_HOME}/src/cvw.sv ${CVW_HOME}/testbench/testbench.sv ${CVW_HOME}/testbench/common/*.sv ${CVW_HOME}/src/*/*.sv ${CVW_HOME}/src/*/*/*.sv --relative-includes
|
|
${CVW_HOME}/sim/verilator/obj_dir/Vtestbench
|
|
fi
|