#!/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 vsim $MSIM_DEFAULT $MSIM_ARGS $MSIM_LIB_ARGS $MSIM_SIM_TOP 2>&1 | while IFS= read -r line; do print_color $line done if [ ${PIPESTATUS[0]} -ne 0 ]; then exit ${PIPESTATUS[0]}; fi elif [ $MSIM_MODE == "batch" ]; then 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 if [ ${PIPESTATUS[0]} -ne 0 ]; then exit ${PIPESTATUS[0]}; fi fi