bench-boot 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #!/usr/bin/env bash
  2. set -eu
  3. root_dir="$(cd "$(dirname "${BASH_SOURCE[0]}")" >/dev/null && pwd)"
  4. test_size=1
  5. OPTIND=1
  6. while getopts t: OPT; do
  7. case "$OPT" in
  8. t)
  9. # 1: a few seconds and important
  10. # 2: < 5 minutes and important or a few seconds and not too important
  11. # 3: all
  12. test_size="$OPTARG"
  13. ;;
  14. ?)
  15. exit 2
  16. ;;
  17. esac
  18. done
  19. shift "$(($OPTIND - 1))"
  20. if [ $# -gt 1 ]; then
  21. extra_args=" $*"
  22. else
  23. extra_args=
  24. fi
  25. getvar="${root_dir}/getvar"
  26. common_bench_boot="$("$getvar" bench_boot)"
  27. caches='--caches --l2cache --l1d_size=1024kB --l1i_size=1024kB --l2_size=1024kB --l3_size=1024kB'
  28. bench() (
  29. "${root_dir}/bench-cmd" "./run --arch ${1}${extra_args}" "$common_bench_boot"
  30. )
  31. gem5_insts() (
  32. printf "instructions $(./gem5-stat --arch "$1" sim_insts)\n" >> "$common_bench_boot"
  33. )
  34. qemu_insts() (
  35. common_arch="$1"
  36. ./qemu-trace2txt --arch "$common_arch"
  37. common_qemu_trace_txt_file="$("$getvar" --arch "$common_arch" qemu_trace_txt_file)"
  38. printf "instructions $(wc -l "${common_qemu_trace_txt_file}" | cut -d' ' -f1)\n" >> "$common_bench_boot"
  39. )
  40. newline() (
  41. echo >> "$common_bench_boot"
  42. )
  43. rm -f "${common_bench_boot}"
  44. arch=x86_64
  45. bench "${arch} --eval '/poweroff.out'"
  46. newline
  47. bench "${arch} --eval '/poweroff.out' --kvm"
  48. newline
  49. if [ "$test_size" -ge 2 ]; then
  50. bench "${arch} --eval '/poweroff.out' --trace exec_tb"
  51. qemu_insts "$arch"
  52. newline
  53. bench "$arch --eval 'm5 exit' --gem5"
  54. gem5_insts "$arch"
  55. newline
  56. fi
  57. #bench "$arch --eval 'm5 exit' --gem5 -- --cpu-type=DerivO3CPU ${caches}"
  58. #gem5_insts "$arch"
  59. #newline
  60. arch=arm
  61. bench "$arch --eval '/poweroff.out'"
  62. newline
  63. if [ "$test_size" -ge 2 ]; then
  64. bench "$arch --eval '/poweroff.out' --trace exec_tb"
  65. qemu_insts "$arch"
  66. newline
  67. #bench "$arch --eval 'm5 exit' --gem5"
  68. #gem5_insts "$arch"
  69. #newline
  70. fi
  71. #if [ "$test_size" -ge 3 ]; then
  72. # bench "$arch --eval 'm5 exit' --gem5 -- --cpu-type=HPI ${caches}"
  73. # gem5_insts "$arch"
  74. # newline
  75. #fi
  76. arch=aarch64
  77. bench "$arch --eval '/poweroff.out'"
  78. newline
  79. if [ "$test_size" -ge 2 ]; then
  80. bench "$arch --eval '/poweroff.out' --trace exec_tb"
  81. qemu_insts "$arch"
  82. newline
  83. bench "$arch --eval 'm5 exit' --gem5"
  84. gem5_insts "$arch"
  85. newline
  86. fi
  87. if [ "$test_size" -ge 3 ]; then
  88. bench "$arch --eval 'm5 exit' --gem5 -- --cpu-type=HPI ${caches}"
  89. gem5_insts "$arch"
  90. newline
  91. fi