| // SPDX-License-Identifier: GPL-2.0 |
| // Copyright (C) 2018 Joe Lawrence <joe.lawrence@redhat.com> |
| |
| #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt |
| |
| #include <linux/module.h> |
| #include <linux/kernel.h> |
| #include <linux/livepatch.h> |
| |
| static int replace; |
| module_param(replace, int, 0644); |
| MODULE_PARM_DESC(replace, "replace (default=0)"); |
| |
| #include <linux/seq_file.h> |
| static int livepatch_meminfo_proc_show(struct seq_file *m, void *v) |
| { |
| seq_printf(m, "%s: %s\n", THIS_MODULE->name, |
| "this has been live patched"); |
| return 0; |
| } |
| |
| static struct klp_func funcs[] = { |
| { |
| .old_name = "meminfo_proc_show", |
| .new_func = livepatch_meminfo_proc_show, |
| }, {} |
| }; |
| |
| static struct klp_object objs[] = { |
| { |
| /* name being NULL means vmlinux */ |
| .funcs = funcs, |
| }, {} |
| }; |
| |
| static struct klp_patch patch = { |
| .mod = THIS_MODULE, |
| .objs = objs, |
| /* set .replace in the init function below for demo purposes */ |
| }; |
| |
| static int test_klp_atomic_replace_init(void) |
| { |
| patch.replace = replace; |
| return klp_enable_patch(&patch); |
| } |
| |
| static void test_klp_atomic_replace_exit(void) |
| { |
| } |
| |
| module_init(test_klp_atomic_replace_init); |
| module_exit(test_klp_atomic_replace_exit); |
| MODULE_LICENSE("GPL"); |
| MODULE_INFO(livepatch, "Y"); |
| MODULE_AUTHOR("Joe Lawrence <joe.lawrence@redhat.com>"); |
| MODULE_DESCRIPTION("Livepatch test: atomic replace"); |