test_kmod.sh 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #!/bin/sh
  2. # SPDX-License-Identifier: GPL-2.0
  3. # Kselftest framework requirement - SKIP code is 4.
  4. ksft_skip=4
  5. msg="skip all tests:"
  6. if [ "$(id -u)" != "0" ]; then
  7. echo $msg please run this as root >&2
  8. exit $ksft_skip
  9. fi
  10. SRC_TREE=../../../../
  11. test_run()
  12. {
  13. sysctl -w net.core.bpf_jit_enable=$1 2>&1 > /dev/null
  14. sysctl -w net.core.bpf_jit_harden=$2 2>&1 > /dev/null
  15. echo "[ JIT enabled:$1 hardened:$2 ]"
  16. dmesg -C
  17. if [ -f ${SRC_TREE}/lib/test_bpf.ko ]; then
  18. insmod ${SRC_TREE}/lib/test_bpf.ko 2> /dev/null
  19. if [ $? -ne 0 ]; then
  20. rc=1
  21. fi
  22. else
  23. # Use modprobe dry run to check for missing test_bpf module
  24. if ! /sbin/modprobe -q -n test_bpf; then
  25. echo "test_bpf: [SKIP]"
  26. elif /sbin/modprobe -q test_bpf; then
  27. echo "test_bpf: ok"
  28. else
  29. echo "test_bpf: [FAIL]"
  30. rc=1
  31. fi
  32. fi
  33. rmmod test_bpf 2> /dev/null
  34. dmesg | grep FAIL
  35. }
  36. test_save()
  37. {
  38. JE=`sysctl -n net.core.bpf_jit_enable`
  39. JH=`sysctl -n net.core.bpf_jit_harden`
  40. }
  41. test_restore()
  42. {
  43. sysctl -w net.core.bpf_jit_enable=$JE 2>&1 > /dev/null
  44. sysctl -w net.core.bpf_jit_harden=$JH 2>&1 > /dev/null
  45. }
  46. rc=0
  47. test_save
  48. test_run 0 0
  49. test_run 1 0
  50. test_run 1 1
  51. test_run 1 2
  52. test_restore
  53. exit $rc