mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-06 05:02:31 +00:00
59766286b6
Save the state of /sys/kernel/debug/kprobes/enabled during setup_config() and restore it during cleanup(). This is in preparation for a future commit that will add a test that should confirm that we cannot livepatch a kprobed function if that kprobe has a post handler. Signed-off-by: Michael Vetter <mvetter@suse.com> Reviewed-by: Miroslav Benes <mbenes@suse.cz> Reviewed-by: Joe Lawrence <joe.lawrence@redhat.com> Tested-by: Marcos Paulo de Souza <mpdesouza@suse.com> Reviewed-by: Marcos Paulo de Souza <mpdesouza@suse.com> Reviewed-by: Petr Mladek <pmladek@suse.com> Tested-by: Petr Mladek <pmladek@suse.com> Link: https://lore.kernel.org/r/20241017200132.21946-3-mvetter@suse.com [pmladek@suse.com: Added few more substitutions in test-syscall.sh] Signed-off-by: Petr Mladek <pmladek@suse.com>
57 lines
1.7 KiB
Bash
Executable File
57 lines
1.7 KiB
Bash
Executable File
#!/bin/bash
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
# Copyright (C) 2023 SUSE
|
|
# Author: Marcos Paulo de Souza <mpdesouza@suse.com>
|
|
|
|
. $(dirname $0)/functions.sh
|
|
|
|
MOD_SYSCALL=test_klp_syscall
|
|
|
|
setup_config
|
|
|
|
# - Start _NRPROC processes calling getpid and load a livepatch to patch the
|
|
# getpid syscall. Check if all the processes transitioned to the livepatched
|
|
# state.
|
|
|
|
start_test "patch getpid syscall while being heavily hammered"
|
|
|
|
NPROC=$(getconf _NPROCESSORS_ONLN)
|
|
MAXPROC=128
|
|
|
|
for i in $(seq 1 $(($NPROC < $MAXPROC ? $NPROC : $MAXPROC))); do
|
|
./test_klp-call_getpid &
|
|
pids[$i]="$!"
|
|
done
|
|
|
|
pid_list=$(echo ${pids[@]} | tr ' ' ',')
|
|
load_lp $MOD_SYSCALL klp_pids=$pid_list
|
|
|
|
# wait for all tasks to transition to patched state
|
|
loop_until 'grep -q '^0$' $SYSFS_KERNEL_DIR/$MOD_SYSCALL/npids'
|
|
|
|
pending_pids=$(cat $SYSFS_KERNEL_DIR/$MOD_SYSCALL/npids)
|
|
log "$MOD_SYSCALL: Remaining not livepatched processes: $pending_pids"
|
|
|
|
for pid in ${pids[@]}; do
|
|
kill $pid || true
|
|
done
|
|
|
|
disable_lp $MOD_SYSCALL
|
|
unload_lp $MOD_SYSCALL
|
|
|
|
check_result "% insmod test_modules/$MOD_SYSCALL.ko klp_pids=$pid_list
|
|
livepatch: enabling patch '$MOD_SYSCALL'
|
|
livepatch: '$MOD_SYSCALL': initializing patching transition
|
|
livepatch: '$MOD_SYSCALL': starting patching transition
|
|
livepatch: '$MOD_SYSCALL': completing patching transition
|
|
livepatch: '$MOD_SYSCALL': patching complete
|
|
$MOD_SYSCALL: Remaining not livepatched processes: 0
|
|
% echo 0 > $SYSFS_KLP_DIR/$MOD_SYSCALL/enabled
|
|
livepatch: '$MOD_SYSCALL': initializing unpatching transition
|
|
livepatch: '$MOD_SYSCALL': starting unpatching transition
|
|
livepatch: '$MOD_SYSCALL': completing unpatching transition
|
|
livepatch: '$MOD_SYSCALL': unpatching complete
|
|
% rmmod $MOD_SYSCALL"
|
|
|
|
exit 0
|