livepatch: Skip livepatch tests if ftrace cannot be configured
authorDavid Vernet <void@manifault.com>
Wed, 16 Feb 2022 16:11:01 +0000 (08:11 -0800)
committerPetr Mladek <pmladek@suse.com>
Wed, 23 Feb 2022 15:42:00 +0000 (16:42 +0100)
livepatch has a set of selftests that are used to validate the behavior of
the livepatching subsystem.  One of the testcases in the livepatch
testsuite is test-ftrace.sh, which among other things, validates that
livepatching gracefully fails when ftrace is disabled.  In the event that
ftrace cannot be disabled using 'sysctl kernel.ftrace_enabled=0', the test
will fail later due to it unexpectedly successfully loading the
test_klp_livepatch module.

While the livepatch selftests are careful to remove any of the livepatch
test modules between testcases to avoid this situation, ftrace may still
fail to be disabled if another trace is active on the system that was
enabled with FTRACE_OPS_FL_PERMANENT.  For example, any active BPF programs
that use trampolines will cause this test to fail due to the trampoline
being implemented with register_ftrace_direct().  The following is an
example of such a trace:

tcp_drop (1) R I D      tramp: ftrace_regs_caller+0x0/0x58
(call_direct_funcs+0x0/0x30)
        direct-->bpf_trampoline_6442550536_0+0x0/0x1000

In order to make the test more resilient to system state that is out of its
control, this patch updates set_ftrace_enabled() to detect sysctl failures,
and skip the testrun when appropriate.

Suggested-by: Petr Mladek <pmladek@suse.com>
Signed-off-by: David Vernet <void@manifault.com>
Acked-by: Miroslav Benes <mbenes@suse.cz>
Reviewed-by: Petr Mladek <pmladek@suse.com>
Tested-by: Petr Mladek <pmladek@suse.com>
Acked-by: Joe Lawrence <joe.lawrence@redhat.com>
Signed-off-by: Petr Mladek <pmladek@suse.com>
Link: https://lore.kernel.org/r/20220216161100.3243100-1-void@manifault.com
tools/testing/selftests/livepatch/functions.sh
tools/testing/selftests/livepatch/test-ftrace.sh

index 846c7ed71556fb542bdf2b8c7135f645c9666b9e..9230b869371d951f33d2286690708889a7e86f92 100644 (file)
@@ -75,9 +75,25 @@ function set_dynamic_debug() {
 }
 
 function set_ftrace_enabled() {
-       result=$(sysctl -q kernel.ftrace_enabled="$1" 2>&1 && \
-                sysctl kernel.ftrace_enabled 2>&1)
-       echo "livepatch: $result" > /dev/kmsg
+       local can_fail=0
+       if [[ "$1" == "--fail" ]] ; then
+               can_fail=1
+               shift
+       fi
+
+       local err=$(sysctl -q kernel.ftrace_enabled="$1" 2>&1)
+       local result=$(sysctl --values kernel.ftrace_enabled)
+
+       if [[ "$result" != "$1" ]] ; then
+               if [[ $can_fail -eq 1 ]] ; then
+                       echo "livepatch: $err" > /dev/kmsg
+                       return
+               fi
+
+               skip "failed to set kernel.ftrace_enabled = $1"
+       fi
+
+       echo "livepatch: kernel.ftrace_enabled = $result" > /dev/kmsg
 }
 
 function cleanup() {
index 552e165512f457692de6fd01e4df1e3dc23393dc..825540a5194d472a122963fdf1b1327aac4e6217 100755 (executable)
@@ -25,7 +25,8 @@ if [[ "$(cat /proc/cmdline)" != "$MOD_LIVEPATCH: this has been live patched" ]]
        die "livepatch kselftest(s) failed"
 fi
 
-set_ftrace_enabled 0
+# 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"