Skip to content

Commit

Permalink
selftests/livepatch: Make dynamic debug setup and restore generic
Browse files Browse the repository at this point in the history
Livepatch selftests currently save the current dynamic debug config and
tweak it for the selftests. The config is restored at the end. Make the
infrastructure generic, so that more variables can be saved and
restored.

Link: http://lkml.kernel.org/r/[email protected]

Signed-off-by: Joe Lawrence <[email protected]>
Signed-off-by: Miroslav Benes <[email protected]>
Signed-off-by: Steven Rostedt (VMware) <[email protected]>
  • Loading branch information
joe-lawrence authored and rostedt committed Nov 4, 2019
1 parent 7162431 commit 35c9e74
Show file tree
Hide file tree
Showing 4 changed files with 16 additions and 12 deletions.
22 changes: 13 additions & 9 deletions tools/testing/selftests/livepatch/functions.sh
Original file line number Diff line number Diff line change
Expand Up @@ -29,29 +29,33 @@ function die() {
exit 1
}

function push_dynamic_debug() {
DYNAMIC_DEBUG=$(grep '^kernel/livepatch' /sys/kernel/debug/dynamic_debug/control | \
awk -F'[: ]' '{print "file " $1 " line " $2 " " $4}')
function push_config() {
DYNAMIC_DEBUG=$(grep '^kernel/livepatch' /sys/kernel/debug/dynamic_debug/control | \
awk -F'[: ]' '{print "file " $1 " line " $2 " " $4}')
}

function pop_dynamic_debug() {
function pop_config() {
if [[ -n "$DYNAMIC_DEBUG" ]]; then
echo -n "$DYNAMIC_DEBUG" > /sys/kernel/debug/dynamic_debug/control
fi
}

# set_dynamic_debug() - save the current dynamic debug config and tweak
# it for the self-tests. Set a script exit trap
# that restores the original config.
function set_dynamic_debug() {
push_dynamic_debug
trap pop_dynamic_debug EXIT INT TERM HUP
cat <<-EOF > /sys/kernel/debug/dynamic_debug/control
file kernel/livepatch/* +p
func klp_try_switch_task -p
EOF
}

# setup_config - save the current config and set a script exit trap that
# restores the original config. Setup the dynamic debug
# for verbose livepatching output.
function setup_config() {
push_config
set_dynamic_debug
trap pop_config EXIT INT TERM HUP
}

# loop_until(cmd) - loop a command until it is successful or $MAX_RETRIES,
# sleep $RETRY_INTERVAL between attempts
# cmd - command and its arguments to run
Expand Down
2 changes: 1 addition & 1 deletion tools/testing/selftests/livepatch/test-callbacks.sh
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ MOD_LIVEPATCH2=test_klp_callbacks_demo2
MOD_TARGET=test_klp_callbacks_mod
MOD_TARGET_BUSY=test_klp_callbacks_busy

set_dynamic_debug
setup_config


# TEST: target module before livepatch
Expand Down
2 changes: 1 addition & 1 deletion tools/testing/selftests/livepatch/test-livepatch.sh
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
MOD_LIVEPATCH=test_klp_livepatch
MOD_REPLACE=test_klp_atomic_replace

set_dynamic_debug
setup_config


# TEST: basic function patching
Expand Down
2 changes: 1 addition & 1 deletion tools/testing/selftests/livepatch/test-shadow-vars.sh
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

MOD_TEST=test_klp_shadow_vars

set_dynamic_debug
setup_config


# TEST: basic shadow variable API
Expand Down

0 comments on commit 35c9e74

Please sign in to comment.