test-ftrace.sh 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. # Copyright (C) 2019 Joe Lawrence <[email protected]>
  4. . $(dirname $0)/functions.sh
  5. MOD_LIVEPATCH=test_klp_livepatch
  6. setup_config
  7. # - turn ftrace_enabled OFF and verify livepatches can't load
  8. # - turn ftrace_enabled ON and verify livepatch can load
  9. # - verify that ftrace_enabled can't be turned OFF while a livepatch is loaded
  10. start_test "livepatch interaction with ftrace_enabled sysctl"
  11. set_ftrace_enabled 0
  12. load_failing_mod $MOD_LIVEPATCH
  13. set_ftrace_enabled 1
  14. load_lp $MOD_LIVEPATCH
  15. if [[ "$(cat /proc/cmdline)" != "$MOD_LIVEPATCH: this has been live patched" ]] ; then
  16. echo -e "FAIL\n\n"
  17. die "livepatch kselftest(s) failed"
  18. fi
  19. # Check that ftrace could not get disabled when a livepatch is enabled
  20. set_ftrace_enabled --fail 0
  21. if [[ "$(cat /proc/cmdline)" != "$MOD_LIVEPATCH: this has been live patched" ]] ; then
  22. echo -e "FAIL\n\n"
  23. die "livepatch kselftest(s) failed"
  24. fi
  25. disable_lp $MOD_LIVEPATCH
  26. unload_lp $MOD_LIVEPATCH
  27. check_result "livepatch: kernel.ftrace_enabled = 0
  28. % modprobe $MOD_LIVEPATCH
  29. livepatch: enabling patch '$MOD_LIVEPATCH'
  30. livepatch: '$MOD_LIVEPATCH': initializing patching transition
  31. livepatch: failed to register ftrace handler for function 'cmdline_proc_show' (-16)
  32. livepatch: failed to patch object 'vmlinux'
  33. livepatch: failed to enable patch '$MOD_LIVEPATCH'
  34. livepatch: '$MOD_LIVEPATCH': canceling patching transition, going to unpatch
  35. livepatch: '$MOD_LIVEPATCH': completing unpatching transition
  36. livepatch: '$MOD_LIVEPATCH': unpatching complete
  37. modprobe: ERROR: could not insert '$MOD_LIVEPATCH': Device or resource busy
  38. livepatch: kernel.ftrace_enabled = 1
  39. % modprobe $MOD_LIVEPATCH
  40. livepatch: enabling patch '$MOD_LIVEPATCH'
  41. livepatch: '$MOD_LIVEPATCH': initializing patching transition
  42. livepatch: '$MOD_LIVEPATCH': starting patching transition
  43. livepatch: '$MOD_LIVEPATCH': completing patching transition
  44. livepatch: '$MOD_LIVEPATCH': patching complete
  45. livepatch: sysctl: setting key \"kernel.ftrace_enabled\": Device or resource busy
  46. % echo 0 > /sys/kernel/livepatch/$MOD_LIVEPATCH/enabled
  47. livepatch: '$MOD_LIVEPATCH': initializing unpatching transition
  48. livepatch: '$MOD_LIVEPATCH': starting unpatching transition
  49. livepatch: '$MOD_LIVEPATCH': completing unpatching transition
  50. livepatch: '$MOD_LIVEPATCH': unpatching complete
  51. % rmmod $MOD_LIVEPATCH"
  52. exit 0