srcu_lockdep.sh 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0+
  3. #
  4. # Run SRCU-lockdep tests and report any that fail to meet expectations.
  5. #
  6. # Copyright (C) 2021 Meta Platforms, Inc.
  7. #
  8. # Authors: Paul E. McKenney <paulmck@kernel.org>
  9. usage () {
  10. echo "Usage: $scriptname optional arguments:"
  11. echo " --datestamp string"
  12. exit 1
  13. }
  14. ds=`date +%Y.%m.%d-%H.%M.%S`-srcu_lockdep
  15. scriptname="$0"
  16. T="`mktemp -d ${TMPDIR-/tmp}/srcu_lockdep.sh.XXXXXX`"
  17. trap 'rm -rf $T' 0
  18. RCUTORTURE="`pwd`/tools/testing/selftests/rcutorture"; export RCUTORTURE
  19. PATH=${RCUTORTURE}/bin:$PATH; export PATH
  20. . functions.sh
  21. while test $# -gt 0
  22. do
  23. case "$1" in
  24. --datestamp)
  25. checkarg --datestamp "(relative pathname)" "$#" "$2" '^[a-zA-Z0-9._/-]*$' '^--'
  26. ds=$2
  27. shift
  28. ;;
  29. *)
  30. echo Unknown argument $1
  31. usage
  32. ;;
  33. esac
  34. shift
  35. done
  36. nerrs=0
  37. # Test lockdep's handling of deadlocks.
  38. for d in 0 1
  39. do
  40. for t in 0 1 2
  41. do
  42. for c in 1 2 3
  43. do
  44. err=
  45. val=$((d*1000+t*10+c))
  46. tools/testing/selftests/rcutorture/bin/kvm.sh --allcpus --duration 5s --configs "SRCU-P" --kconfig "CONFIG_FORCE_NEED_SRCU_NMI_SAFE=y" --bootargs "rcutorture.test_srcu_lockdep=$val rcutorture.reader_flavor=0x2" --trust-make --datestamp "$ds/$val" > "$T/kvm.sh.out" 2>&1
  47. ret=$?
  48. mv "$T/kvm.sh.out" "$RCUTORTURE/res/$ds/$val"
  49. if ! grep -q '^CONFIG_PROVE_LOCKING=y' .config
  50. then
  51. echo "rcu_torture_init_srcu_lockdep:Error: CONFIG_PROVE_LOCKING disabled in rcutorture SRCU-P scenario"
  52. nerrs=$((nerrs+1))
  53. err=1
  54. fi
  55. if test "$d" -ne 0 && test "$ret" -eq 0
  56. then
  57. err=1
  58. echo -n Unexpected success for > "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  59. fi
  60. if test "$d" -eq 0 && test "$ret" -ne 0
  61. then
  62. err=1
  63. echo -n Unexpected failure for > "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  64. fi
  65. if test -n "$err"
  66. then
  67. grep "rcu_torture_init_srcu_lockdep: test_srcu_lockdep = " "$RCUTORTURE/res/$ds/$val/SRCU-P/console.log" | sed -e 's/^.*rcu_torture_init_srcu_lockdep://' >> "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  68. cat "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  69. nerrs=$((nerrs+1))
  70. fi
  71. done
  72. done
  73. done
  74. # Test lockdep-enabled testing of mixed SRCU readers.
  75. for val in 0x1 0xf
  76. do
  77. err=
  78. tools/testing/selftests/rcutorture/bin/kvm.sh --allcpus --duration 5s --configs "SRCU-P" --kconfig "CONFIG_FORCE_NEED_SRCU_NMI_SAFE=y" --bootargs "rcutorture.reader_flavor=$val" --trust-make --datestamp "$ds/$val" > "$T/kvm.sh.out" 2>&1
  79. ret=$?
  80. mv "$T/kvm.sh.out" "$RCUTORTURE/res/$ds/$val"
  81. if ! grep -q '^CONFIG_PROVE_LOCKING=y' .config
  82. then
  83. echo "rcu_torture_init_srcu_lockdep:Error: CONFIG_PROVE_LOCKING disabled in rcutorture SRCU-P scenario"
  84. nerrs=$((nerrs+1))
  85. err=1
  86. fi
  87. if test "$val" -eq 0xf && test "$ret" -eq 0
  88. then
  89. err=1
  90. echo -n Unexpected success for > "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  91. fi
  92. if test "$val" -eq 0x1 && test "$ret" -ne 0
  93. then
  94. err=1
  95. echo -n Unexpected failure for > "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  96. fi
  97. if test -n "$err"
  98. then
  99. grep "rcu_torture_init_srcu_lockdep: test_srcu_lockdep = " "$RCUTORTURE/res/$ds/$val/SRCU-P/console.log" | sed -e 's/^.*rcu_torture_init_srcu_lockdep://' >> "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  100. cat "$RCUTORTURE/res/$ds/$val/kvm.sh.err"
  101. nerrs=$((nerrs+1))
  102. fi
  103. done
  104. # Set up exit code.
  105. if test "$nerrs" -ne 0
  106. then
  107. exit 1
  108. fi
  109. exit 0