mirror of
https://github.com/saymrwulf/uhd.git
synced 2026-05-16 21:10:10 +00:00
73 lines
2 KiB
Bash
Executable file
73 lines
2 KiB
Bash
Executable file
#!/bin/bash
|
|
|
|
#------------------------------------------
|
|
# Colorize
|
|
#------------------------------------------
|
|
|
|
# VIV_COLOR_SCHEME must be defined in the environment setup script
|
|
case "$VIV_COLOR_SCHEME" in
|
|
default)
|
|
CLR_OFF='tput sgr0'
|
|
ERR_CLR='tput setaf 1'
|
|
WARN_CLR='tput setaf 3'
|
|
INFO_CLR='tput setaf 6'
|
|
;;
|
|
*)
|
|
CLR_OFF=''
|
|
ERR_CLR=$CLR_OFF
|
|
WARN_CLR=$CLR_OFF
|
|
INFO_CLR=$CLR_OFF
|
|
esac
|
|
|
|
# Display output string colorized
|
|
function print_color {
|
|
case $line in
|
|
*Fatal:*|*Failure:*)
|
|
eval $ERR_CLR; echo "$line"; eval $CLR_OFF
|
|
;;
|
|
*Error:*|*Error[[:space:]]\(suppressible\):*)
|
|
eval $ERR_CLR; echo "$line"; eval $CLR_OFF
|
|
;;
|
|
*Warning:*)
|
|
eval $WARN_CLR; echo "$line"; eval $CLR_OFF
|
|
;;
|
|
*Info:*|*Note:*)
|
|
eval $INFO_CLR; echo "$line"; eval $CLR_OFF
|
|
;;
|
|
*)
|
|
echo "$line"
|
|
esac
|
|
}
|
|
|
|
#------------------------------------------
|
|
# Launch ModelSim
|
|
#------------------------------------------
|
|
|
|
# Using -voptargs=+acc makes everything visible in the simulator for GUI mode
|
|
# and avoids some cases where simulation mismatch could otherwise occur.
|
|
MSIM_DEFAULT="-voptargs=+acc -quiet -L unisims_ver"
|
|
|
|
cd $MSIM_PROJ_DIR
|
|
|
|
# Generate the library options string
|
|
MSIM_LIB_ARGS=
|
|
for lib in $MSIM_LIBS
|
|
do
|
|
MSIM_LIB_ARGS+="-L $lib "
|
|
done
|
|
|
|
if [ $MSIM_MODE == "gui" ]; then
|
|
echo "* Launching ModelSim"
|
|
vsim $MSIM_DEFAULT $MSIM_ARGS $MSIM_LIB_ARGS $MSIM_SIM_TOP 2>&1 | while IFS= read -r line; do
|
|
print_color $line
|
|
done
|
|
exit_status=${PIPESTATUS[0]}
|
|
if [ ${exit_status} -ne 0 ]; then exit ${exit_status}; fi
|
|
elif [ $MSIM_MODE == "batch" ]; then
|
|
echo "* Launching ModelSim"
|
|
vsim -batch -do "run -all; quit -f" $MSIM_DEFAULT $MSIM_ARGS $MSIM_LIB_ARGS $MSIM_SIM_TOP 2>&1 | while IFS= read -r line; do
|
|
print_color $line
|
|
done
|
|
exit_status=${PIPESTATUS[0]}
|
|
if [ ${exit_status} -ne 0 ]; then exit ${exit_status}; fi
|
|
fi
|