12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- #!/bin/bash
- # SPDX-License-Identifier: GPL-2.0
- # Copyright (C) 2019 Joe Lawrence <[email protected]>
- . $(dirname $0)/functions.sh
- MOD_LIVEPATCH=test_klp_livepatch
- setup_config
- # - turn ftrace_enabled OFF and verify livepatches can't load
- # - turn ftrace_enabled ON and verify livepatch can load
- # - verify that ftrace_enabled can't be turned OFF while a livepatch is loaded
- start_test "livepatch interaction with ftrace_enabled sysctl"
- set_ftrace_enabled 0
- load_failing_mod $MOD_LIVEPATCH
- set_ftrace_enabled 1
- load_lp $MOD_LIVEPATCH
- if [[ "$(cat /proc/cmdline)" != "$MOD_LIVEPATCH: this has been live patched" ]] ; then
- echo -e "FAIL\n\n"
- die "livepatch kselftest(s) failed"
- fi
- # Check that ftrace could not get disabled when a livepatch is enabled
- set_ftrace_enabled --fail 0
- if [[ "$(cat /proc/cmdline)" != "$MOD_LIVEPATCH: this has been live patched" ]] ; then
- echo -e "FAIL\n\n"
- die "livepatch kselftest(s) failed"
- fi
- disable_lp $MOD_LIVEPATCH
- unload_lp $MOD_LIVEPATCH
- check_result "livepatch: kernel.ftrace_enabled = 0
- % modprobe $MOD_LIVEPATCH
- livepatch: enabling patch '$MOD_LIVEPATCH'
- livepatch: '$MOD_LIVEPATCH': initializing patching transition
- livepatch: failed to register ftrace handler for function 'cmdline_proc_show' (-16)
- livepatch: failed to patch object 'vmlinux'
- livepatch: failed to enable patch '$MOD_LIVEPATCH'
- livepatch: '$MOD_LIVEPATCH': canceling patching transition, going to unpatch
- livepatch: '$MOD_LIVEPATCH': completing unpatching transition
- livepatch: '$MOD_LIVEPATCH': unpatching complete
- modprobe: ERROR: could not insert '$MOD_LIVEPATCH': Device or resource busy
- livepatch: kernel.ftrace_enabled = 1
- % modprobe $MOD_LIVEPATCH
- livepatch: enabling patch '$MOD_LIVEPATCH'
- livepatch: '$MOD_LIVEPATCH': initializing patching transition
- livepatch: '$MOD_LIVEPATCH': starting patching transition
- livepatch: '$MOD_LIVEPATCH': completing patching transition
- livepatch: '$MOD_LIVEPATCH': patching complete
- livepatch: sysctl: setting key \"kernel.ftrace_enabled\": Device or resource busy
- % echo 0 > /sys/kernel/livepatch/$MOD_LIVEPATCH/enabled
- livepatch: '$MOD_LIVEPATCH': initializing unpatching transition
- livepatch: '$MOD_LIVEPATCH': starting unpatching transition
- livepatch: '$MOD_LIVEPATCH': completing unpatching transition
- livepatch: '$MOD_LIVEPATCH': unpatching complete
- % rmmod $MOD_LIVEPATCH"
- exit 0
|