log_pass() { printf "%-15s %s %s %s\n" "$1" "$2" "`printf "%20s" "$2" | tr -d a-zA-Z0-9_ | tr ' ' .`" "pass." } log_fail() { printf "%-15s %s %s %s\n" "$1" "$2" "`printf "%20s" "$2" | tr -d a-zA-Z0-9_ | tr ' ' .`" "FAIL." } test_autotest() { # Usage: # test_autotest <test_name> <synth_script> <mod_name> <vlog_file> test_name="$1" synth_cmd="$2" mod_name="$3" vlog_file="$4" mkdir -p log_test_$test_name rm -rf log_test_$test_name/$mod_name.* ../../yosys -q -l log_test_$test_name/$mod_name.out -o log_test_$test_name/$mod_name.v -p "$synth_cmd" "$vlog_file" cat spec/${mod_name}_spec.v scripts/check.v >> log_test_$test_name/$mod_name.v iverilog -o log_test_$test_name/$mod_name.bin -D"REFDAT_FN=\"refdat/${mod_name}_refdat.txt\"" log_test_$test_name/$mod_name.v if log_test_$test_name/$mod_name.bin 2>&1 | tee -a log_test_$test_name/$mod_name.out | grep -q '++OK++'; then mv log_test_$test_name/$mod_name.out log_test_$test_name/$mod_name.txt log_pass test_$test_name $mod_name else mv log_test_$test_name/$mod_name.out log_test_$test_name/$mod_name.err log_fail test_$test_name $mod_name exit 1 fi } 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 .. miter -equiv -ignore_gold_x -make_outputs -make_outcmp gold work miter flatten miter 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 } test_febe() { # Usage: # test_febe <test_name> <synth_script> <extension> <backend> <frontend> <sat_options> <mod_name> <vlog_file> # $1 $2 $3 $4 $5 $6 $7 $8 mkdir -p log_test_$1 rm -f log_test_$1/$7.txt rm -f log_test_$1/$7.err if ! ../../yosys -q -l log_test_$1/$7.out - 2> /dev/null <<- EOT echo on read_verilog $8 $2 design -save gold dump $4 log_test_$1/$7$3 design -reset $5 log_test_$1/$7$3 design -copy-from gold -as gold $7 rename $7 gate miter -equiv -flatten -ignore_gold_x -make_outputs -make_outcmp gold gate miter sat $6 -verify -prove trigger 0 -show-inputs -show-outputs miter EOT then log_fail test_$1 $7 mv log_test_$1/$7.out log_test_$1/$7.err exit 1 fi log_pass test_$1 $7 mv log_test_$1/$7.out log_test_$1/$7.txt }