2014-07-21 07:08:13 -05:00
|
|
|
log_pass()
|
|
|
|
{
|
2014-07-20 06:20:52 -05:00
|
|
|
printf "%-15s %s %s %s\n" "$1" "$2" "`printf "%20s" "$2" | tr -d a-zA-Z0-9_ | tr ' ' .`" "pass."
|
|
|
|
}
|
|
|
|
|
2014-07-21 07:08:13 -05:00
|
|
|
log_fail()
|
|
|
|
{
|
2014-07-20 06:20:52 -05:00
|
|
|
printf "%-15s %s %s %s\n" "$1" "$2" "`printf "%20s" "$2" | tr -d a-zA-Z0-9_ | tr ' ' .`" "FAIL."
|
|
|
|
}
|
2014-07-21 07:08:13 -05:00
|
|
|
|
|
|
|
test_equiv()
|
|
|
|
{
|
|
|
|
# Usage:
|
|
|
|
# test_equiv <test_name> <synth_script> <sat_options> <mod_name> <vlog_file>
|
|
|
|
|
|
|
|
mkdir -p log_test_$1
|
|
|
|
rm -f log_test_$1/$4.txt
|
|
|
|
rm -f log_test_$1/$4.err
|
|
|
|
|
|
|
|
if ! ../../yosys -q -l log_test_$1/$4.out - 2> /dev/null <<- EOT
|
|
|
|
read_verilog $5
|
|
|
|
proc;;
|
|
|
|
|
|
|
|
copy $4 gold
|
|
|
|
rename $4 work
|
|
|
|
|
|
|
|
cd work
|
|
|
|
$2
|
|
|
|
cd ..
|
|
|
|
|
2014-07-21 14:39:59 -05:00
|
|
|
miter -equiv -ignore_gold_x -make_outputs -make_outcmp gold work miter
|
|
|
|
flatten miter
|
2014-07-21 07:08:13 -05:00
|
|
|
sat $3 -verify -prove trigger 0 -show-inputs -show-outputs miter
|
|
|
|
EOT
|
|
|
|
then
|
|
|
|
log_fail test_$1 $4
|
|
|
|
mv log_test_$1/$4.out log_test_$1/$4.err
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
log_pass test_$1 $4
|
|
|
|
mv log_test_$1/$4.out log_test_$1/$4.txt
|
|
|
|
}
|