2013-01-05 04:13:26 -06:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
|
|
libs=""
|
|
|
|
genvcd=false
|
2014-02-03 06:00:55 -06:00
|
|
|
use_xsim=false
|
2013-11-24 08:10:43 -06:00
|
|
|
use_modelsim=false
|
2013-01-05 04:13:26 -06:00
|
|
|
verbose=false
|
|
|
|
keeprunning=false
|
|
|
|
backend_opts="-noattr -noexpr"
|
|
|
|
scriptfiles=""
|
2014-01-02 10:51:30 -06:00
|
|
|
scriptopt=""
|
2013-01-05 04:13:26 -06:00
|
|
|
toolsdir="$(cd $(dirname $0); pwd)"
|
|
|
|
|
|
|
|
if [ ! -f $toolsdir/cmp_tbdata -o $toolsdir/cmp_tbdata.c -nt $toolsdir/cmp_tbdata ]; then
|
|
|
|
( set -ex; gcc -Wall -o $toolsdir/cmp_tbdata $toolsdir/cmp_tbdata.c; ) || exit 1
|
|
|
|
fi
|
|
|
|
|
2014-02-03 06:00:55 -06:00
|
|
|
while getopts xml:wkvrs:p: opt; do
|
2013-01-05 04:13:26 -06:00
|
|
|
case "$opt" in
|
2014-02-03 06:00:55 -06:00
|
|
|
x)
|
|
|
|
use_xsim=true ;;
|
2013-11-24 08:10:43 -06:00
|
|
|
m)
|
|
|
|
use_modelsim=true ;;
|
2013-01-05 04:13:26 -06:00
|
|
|
l)
|
|
|
|
libs="$libs $(cd $(dirname $OPTARG); pwd)/$(basename $OPTARG)";;
|
|
|
|
w)
|
|
|
|
genvcd=true ;;
|
|
|
|
k)
|
|
|
|
keeprunning=true ;;
|
|
|
|
v)
|
|
|
|
verbose=true ;;
|
|
|
|
r)
|
2014-01-02 10:51:30 -06:00
|
|
|
backend_opts="$backend_opts -norename" ;;
|
2013-01-05 04:13:26 -06:00
|
|
|
s)
|
|
|
|
[[ "$OPTARG" == /* ]] || OPTARG="$PWD/$OPTARG"
|
|
|
|
scriptfiles="$scriptfiles $OPTARG" ;;
|
2014-01-02 10:51:30 -06:00
|
|
|
p)
|
|
|
|
scriptopt="$OPTARG" ;;
|
2013-01-05 04:13:26 -06:00
|
|
|
*)
|
2014-02-03 06:00:55 -06:00
|
|
|
echo "Usage: $0 [-x|-m] [-w] [-k] [-v] [-r] [-l libs] [-s script] [-p cmdstring] verilog-files\n" >&2
|
2013-01-05 04:13:26 -06:00
|
|
|
exit 1
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
create_ref() {
|
2014-02-03 06:00:55 -06:00
|
|
|
cp "$1" "$2.v"
|
2013-01-05 04:13:26 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
compile_and_run() {
|
|
|
|
exe="$1"; output="$2"; shift 2
|
2013-11-24 08:10:43 -06:00
|
|
|
if $use_modelsim; then
|
|
|
|
altver=$( ls -v /opt/altera/ | grep '^[0-9]' | tail -n1; )
|
|
|
|
/opt/altera/$altver/modelsim_ase/bin/vlib work
|
|
|
|
/opt/altera/$altver/modelsim_ase/bin/vlog "$@"
|
|
|
|
/opt/altera/$altver/modelsim_ase/bin/vsim -c -do 'run -all; exit;' testbench | grep '#OUT#' > "$output"
|
2014-02-03 06:00:55 -06:00
|
|
|
elif $use_xsim; then
|
2013-01-05 04:13:26 -06:00
|
|
|
(
|
|
|
|
set +x
|
|
|
|
files=( "$@" )
|
2014-02-03 06:00:55 -06:00
|
|
|
xilver=$( ls -v /opt/Xilinx/Vivado/ | grep '^[0-9]' | tail -n1; )
|
|
|
|
/opt/Xilinx/Vivado/$xilver/bin/xvlog "${files[@]}"
|
|
|
|
/opt/Xilinx/Vivado/$xilver/bin/xelab -R work.testbench | grep '#OUT#' > "$output"
|
2013-01-05 04:13:26 -06:00
|
|
|
)
|
|
|
|
else
|
|
|
|
iverilog -s testbench -o "$exe" "$@"
|
|
|
|
vvp -n "$exe" > "$output"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
shift $((OPTIND - 1))
|
|
|
|
|
|
|
|
for fn
|
|
|
|
do
|
|
|
|
bn=${fn%.v}
|
|
|
|
if [ "$bn" == "$fn" ]; then
|
|
|
|
echo "Invalid argument: $fn" >&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
[[ "$bn" == *_tb ]] && continue
|
|
|
|
echo -n "Test: $bn "
|
|
|
|
|
|
|
|
rm -f ${bn}.{err,log}
|
|
|
|
mkdir -p ${bn}.out
|
|
|
|
rm -rf ${bn}.out/*
|
|
|
|
|
|
|
|
body() {
|
|
|
|
cd ${bn}.out
|
|
|
|
cp ../$fn $fn
|
|
|
|
if [ ! -f ../${bn}_tb.v ]; then
|
|
|
|
"$toolsdir"/../../yosys -b autotest -o ${bn}_tb.v $fn
|
|
|
|
else
|
|
|
|
cp ../${bn}_tb.v ${bn}_tb.v
|
|
|
|
fi
|
|
|
|
if $genvcd; then sed -i 's,// \$dump,$dump,g' ${bn}_tb.v; fi
|
|
|
|
create_ref $fn ${bn}_ref
|
|
|
|
compile_and_run ${bn}_tb_ref ${bn}_out_ref ${bn}_tb.v ${bn}_ref.v $libs
|
|
|
|
if $genvcd; then mv testbench.vcd ${bn}_ref.vcd; fi
|
|
|
|
|
|
|
|
test_count=0
|
|
|
|
test_passes() {
|
|
|
|
"$toolsdir"/../../yosys -b "verilog $backend_opts" "$@" -o ${bn}_syn${test_count}.v $fn $scriptfiles
|
|
|
|
compile_and_run ${bn}_tb_syn${test_count} ${bn}_out_syn${test_count} \
|
|
|
|
${bn}_tb.v ${bn}_syn${test_count}.v $libs \
|
2013-09-15 04:52:57 -05:00
|
|
|
"$toolsdir"/../../techlibs/common/simlib.v \
|
2013-11-24 13:44:00 -06:00
|
|
|
"$toolsdir"/../../techlibs/common/simcells.v
|
2013-01-05 04:13:26 -06:00
|
|
|
if $genvcd; then mv testbench.vcd ${bn}_syn${test_count}.vcd; fi
|
|
|
|
$toolsdir/cmp_tbdata ${bn}_out_ref ${bn}_out_syn${test_count}
|
|
|
|
test_count=$(( test_count + 1 ))
|
|
|
|
}
|
|
|
|
|
|
|
|
if [ -n "$scriptfiles" ]; then
|
|
|
|
test_passes
|
2014-01-02 10:51:30 -06:00
|
|
|
elif [ -n "$scriptopt" ]; then
|
|
|
|
test_passes -p "$scriptopt"
|
2013-01-05 04:13:26 -06:00
|
|
|
else
|
2013-12-31 14:25:34 -06:00
|
|
|
test_passes -p "hierarchy; proc; opt; memory; opt; fsm; opt"
|
|
|
|
test_passes -p "hierarchy; proc; opt; memory; opt; fsm; opt; techmap; opt; abc -dff; opt"
|
2013-01-05 04:13:26 -06:00
|
|
|
fi
|
|
|
|
touch ../${bn}.log
|
|
|
|
}
|
|
|
|
|
|
|
|
if $verbose; then
|
|
|
|
echo ".."
|
|
|
|
echo "Output written to console." > ${bn}.err
|
|
|
|
( set -ex; body; )
|
|
|
|
else
|
|
|
|
( set -ex; body; ) > ${bn}.err 2>&1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -f ${bn}.log ]; then
|
|
|
|
mv ${bn}.err ${bn}.log
|
|
|
|
echo "-> ok"
|
|
|
|
else echo "-> ERROR!"; $keeprunning || exit 1; fi
|
|
|
|
done
|
|
|
|
|
|
|
|
exit 0
|