This commit removes the use of callbacks in the sysfs interface testing. The callbacks are not necessary for this testing and create unnecessary noise. This commit replaces the test modules that use the obsolete per-object callbacks with a simple test module in a "Hello World" style and a corresponding livepatch. These new modules will be extended in the future to include an optional integration of livepatch states, per-state callbacks, and shadow variables. They will be used for testing all the new features. Signed-off-by: Petr Mladek <pmladek@xxxxxxxx> --- .../testing/selftests/livepatch/test-sysfs.sh | 48 ++++++--------- .../selftests/livepatch/test_modules/Makefile | 2 + .../livepatch/test_modules/test_klp_speaker.c | 38 ++++++++++++ .../test_modules/test_klp_speaker_livepatch.c | 61 +++++++++++++++++++ 4 files changed, 121 insertions(+), 28 deletions(-) create mode 100644 tools/testing/selftests/livepatch/test_modules/test_klp_speaker.c create mode 100644 tools/testing/selftests/livepatch/test_modules/test_klp_speaker_livepatch.c diff --git a/tools/testing/selftests/livepatch/test-sysfs.sh b/tools/testing/selftests/livepatch/test-sysfs.sh index 2c91428d2997..c565e6005710 100755 --- a/tools/testing/selftests/livepatch/test-sysfs.sh +++ b/tools/testing/selftests/livepatch/test-sysfs.sh @@ -43,8 +43,8 @@ livepatch: '$MOD_LIVEPATCH': unpatching complete start_test "sysfs test object/patched" -MOD_LIVEPATCH=test_klp_callbacks_demo -MOD_TARGET=test_klp_callbacks_mod +MOD_LIVEPATCH=test_klp_speaker_livepatch +MOD_TARGET=test_klp_speaker load_lp $MOD_LIVEPATCH # check the "patch" file changes as target module loads/unloads @@ -57,32 +57,24 @@ check_sysfs_value "$MOD_LIVEPATCH" "$MOD_TARGET/patched" "0" disable_lp $MOD_LIVEPATCH unload_lp $MOD_LIVEPATCH -check_result "% insmod test_modules/test_klp_callbacks_demo.ko -livepatch: enabling patch 'test_klp_callbacks_demo' -livepatch: 'test_klp_callbacks_demo': initializing patching transition -test_klp_callbacks_demo: pre_patch_callback: vmlinux -livepatch: 'test_klp_callbacks_demo': starting patching transition -livepatch: 'test_klp_callbacks_demo': completing patching transition -test_klp_callbacks_demo: post_patch_callback: vmlinux -livepatch: 'test_klp_callbacks_demo': patching complete -% insmod test_modules/test_klp_callbacks_mod.ko -livepatch: applying patch 'test_klp_callbacks_demo' to loading module 'test_klp_callbacks_mod' -test_klp_callbacks_demo: pre_patch_callback: test_klp_callbacks_mod -> [MODULE_STATE_COMING] Full formed, running module_init -test_klp_callbacks_demo: post_patch_callback: test_klp_callbacks_mod -> [MODULE_STATE_COMING] Full formed, running module_init -test_klp_callbacks_mod: test_klp_callbacks_mod_init -% rmmod test_klp_callbacks_mod -test_klp_callbacks_mod: test_klp_callbacks_mod_exit -test_klp_callbacks_demo: pre_unpatch_callback: test_klp_callbacks_mod -> [MODULE_STATE_GOING] Going away -livepatch: reverting patch 'test_klp_callbacks_demo' on unloading module 'test_klp_callbacks_mod' -test_klp_callbacks_demo: post_unpatch_callback: test_klp_callbacks_mod -> [MODULE_STATE_GOING] Going away -% echo 0 > $SYSFS_KLP_DIR/test_klp_callbacks_demo/enabled -livepatch: 'test_klp_callbacks_demo': initializing unpatching transition -test_klp_callbacks_demo: pre_unpatch_callback: vmlinux -livepatch: 'test_klp_callbacks_demo': starting unpatching transition -livepatch: 'test_klp_callbacks_demo': completing unpatching transition -test_klp_callbacks_demo: post_unpatch_callback: vmlinux -livepatch: 'test_klp_callbacks_demo': unpatching complete -% rmmod test_klp_callbacks_demo" +check_result "% insmod test_modules/$MOD_LIVEPATCH.ko +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 +% insmod test_modules/$MOD_TARGET.ko +livepatch: applying patch '$MOD_LIVEPATCH' to loading module '$MOD_TARGET' +$MOD_TARGET: ${MOD_TARGET}_init +% rmmod $MOD_TARGET +$MOD_TARGET: ${MOD_TARGET}_exit +livepatch: reverting patch '$MOD_LIVEPATCH' on unloading module '$MOD_TARGET' +% echo 0 > $SYSFS_KLP_DIR/$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" start_test "sysfs test replace enabled" diff --git a/tools/testing/selftests/livepatch/test_modules/Makefile b/tools/testing/selftests/livepatch/test_modules/Makefile index 939230e571f5..0978c489a67a 100644 --- a/tools/testing/selftests/livepatch/test_modules/Makefile +++ b/tools/testing/selftests/livepatch/test_modules/Makefile @@ -9,6 +9,8 @@ obj-m += test_klp_atomic_replace.o \ test_klp_kprobe.o \ test_klp_livepatch.o \ test_klp_shadow_vars.o \ + test_klp_speaker.o \ + test_klp_speaker_livepatch.o \ test_klp_state.o \ test_klp_state2.o \ test_klp_state3.o \ diff --git a/tools/testing/selftests/livepatch/test_modules/test_klp_speaker.c b/tools/testing/selftests/livepatch/test_modules/test_klp_speaker.c new file mode 100644 index 000000000000..b1fb135820b0 --- /dev/null +++ b/tools/testing/selftests/livepatch/test_modules/test_klp_speaker.c @@ -0,0 +1,38 @@ +// SPDX-License-Identifier: GPL-2.0 +// Copyright (C) 2024 SUSE + +#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt + +#include <linux/module.h> +#include <linux/printk.h> + +/** + * test_klp_speaker - test module for testing misc livepatching features + * + * The module provides a virtual speaker who can do: + * + * - Start a show with a greeting, see speaker_welcome(). + */ + +noinline +static void __always_used speaker_welcome(void) +{ + pr_info("%s: Hello, World!\n", __func__); +} + +static int test_klp_speaker_init(void) +{ + pr_info("%s\n", __func__); + + return 0; +} + +static void test_klp_speaker_exit(void) +{ + pr_info("%s\n", __func__); +} + +module_init(test_klp_speaker_init); +module_exit(test_klp_speaker_exit); +MODULE_LICENSE("GPL"); +MODULE_DESCRIPTION("Livepatch test: test functions"); diff --git a/tools/testing/selftests/livepatch/test_modules/test_klp_speaker_livepatch.c b/tools/testing/selftests/livepatch/test_modules/test_klp_speaker_livepatch.c new file mode 100644 index 000000000000..26a8dd15f723 --- /dev/null +++ b/tools/testing/selftests/livepatch/test_modules/test_klp_speaker_livepatch.c @@ -0,0 +1,61 @@ +// SPDX-License-Identifier: GPL-2.0 +// Copyright (C) 2024 SUSE + +#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt + +#include <linux/module.h> +#include <linux/kernel.h> +#include <linux/livepatch.h> +#include <linux/init.h> + +/** + * test_klp_speaker_livepatch - test livepatch for testing various livepatching + * features. + * + * The livepatch modifies the behavior of a virtual speaker provided by + * the module test_klp_speaker. It can do: + * + * - Improve the speaker's greeting from "Hello, World!" to + * "Ladies and gentleman, ..." + */ + +static void lp_speaker_welcome(void) +{ + pr_info("%s: Ladies and gentleman, ...\n", __func__); +} + +static struct klp_func test_klp_speaker_funcs[] = { + { + .old_name = "speaker_welcome", + .new_func = lp_speaker_welcome, + }, + { } +}; + +static struct klp_object objs[] = { + { + .name = "test_klp_speaker", + .funcs = test_klp_speaker_funcs, + }, + { } +}; + +static struct klp_patch patch = { + .mod = THIS_MODULE, + .objs = objs, +}; + +static int test_klp_speaker_livepatch_init(void) +{ + return klp_enable_patch(&patch); +} + +static void test_klp_speaker_livepatch_exit(void) +{ +} + +module_init(test_klp_speaker_livepatch_init); +module_exit(test_klp_speaker_livepatch_exit); +MODULE_LICENSE("GPL"); +MODULE_INFO(livepatch, "Y"); +MODULE_DESCRIPTION("Livepatch test: livepatch test_klp_speaker test module"); -- 2.47.1