lowRISC Contributors | 802543a | 2019-08-31 12:12:56 +0100 | [diff] [blame] | 1 | #!/bin/bash |
| 2 | |
| 3 | # to run rtl_diff (Conformal LEC) on all modules, type |
| 4 | # rtl_diff_all |
| 5 | |
| 6 | #------------------------------------------------------------------------- |
| 7 | # list all blocks |
| 8 | #------------------------------------------------------------------------- |
| 9 | declare -a blocks=( |
| 10 | "gpio" |
| 11 | "rv_core_ibex" |
| 12 | "rv_dm" |
| 13 | "rv_plic" |
| 14 | "spi_device" |
| 15 | "rv_timer" |
| 16 | "uart" |
| 17 | "hmac" |
| 18 | "flash_ctrl" |
lowRISC Contributors | 802543a | 2019-08-31 12:12:56 +0100 | [diff] [blame] | 19 | "usbdev" |
| 20 | "usb_fs_nb_pe" |
| 21 | "tlul_adapter_sram" |
| 22 | "tlul_socket_1n" |
| 23 | "tlul_socket_m1" |
| 24 | "sram2tlul" |
| 25 | "top_earlgrey" |
| 26 | ) |
| 27 | |
| 28 | #------------------------------------------------------------------------- |
| 29 | # print header |
| 30 | #------------------------------------------------------------------------- |
| 31 | printf "LEC RESULTS (RTL vs. RTL) \n\n" |
| 32 | format="%18s %10s \n" |
| 33 | printf "${format}" "Block" "Result" |
| 34 | echo "------------------------------" |
| 35 | |
| 36 | #------------------------------------------------------------------------- |
| 37 | # run rtl_diff and summarize results |
| 38 | #------------------------------------------------------------------------- |
| 39 | \rm -Rf lec_*.log |
| 40 | |
| 41 | for block in "${blocks[@]}" ; do |
| 42 | |
| 43 | # set full path to module $block |
| 44 | if [ $block == "top_earlgrey" ]; then |
| 45 | block_full="../${block}/rtl/${block}.sv" |
| 46 | elif [ $block == "usb_fs_nb_pe" ]; then |
| 47 | block_full="../ip/usbfs_nb_pe/rtl/${block}.sv" |
lowRISC Contributors | 802543a | 2019-08-31 12:12:56 +0100 | [diff] [blame] | 48 | elif [[ $block =~ "tlul" ]]; then |
| 49 | block_full="../ip/tlul/rtl/${block}.sv" |
Nils Graf | 0584991 | 2019-09-12 08:27:26 -0700 | [diff] [blame] | 50 | elif [[ $block == "rv_plic" ]]; then |
Philipp Wagner | c720ac8 | 2021-03-03 15:34:53 +0000 | [diff] [blame] | 51 | block_full="../top_earlgrey/ip_autogen/${block}/rtl/${block}.sv" |
lowRISC Contributors | 802543a | 2019-08-31 12:12:56 +0100 | [diff] [blame] | 52 | else |
| 53 | block_full="../ip/${block}/rtl/${block}.sv" |
| 54 | fi |
| 55 | |
| 56 | # run rtl_diff for module $block_full vs. itself |
| 57 | rtl_diff $block_full $block_full > /dev/null 2>&1 |
| 58 | cp rtl_diff.log lec_${block}.log |
| 59 | |
| 60 | # summarize results |
| 61 | result=`grep "Compare Results" rtl_diff.log` |
| 62 | if [ $? -ne 0 ]; then |
| 63 | printf "${format}" $block "CRASH" |
| 64 | else |
| 65 | result=`echo $result | awk '{ print $4 }'` |
| 66 | printf "${format}" $block $result |
| 67 | fi |
| 68 | done |
| 69 | |
| 70 | #------------------------------------------------------------------------- |
| 71 | # print errors |
| 72 | #------------------------------------------------------------------------- |
| 73 | printf "\n\nLIST OF ERRORS:" |
| 74 | |
| 75 | for block in "${blocks[@]}" ; do |
| 76 | egrep -A 2 "(Error:|ERROR )" lec_${block}.log > /dev/null 2>&1 |
| 77 | if [ $? -eq 0 ]; then |
| 78 | printf "\n\n${block}\n" |
| 79 | egrep -A 2 "(Error:|ERROR )" lec_${block}.log |
| 80 | fi |
| 81 | done |