18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 28c2ecf20Sopenharmony_ci// Copyright (C) 2018 Joe Lawrence <joe.lawrence@redhat.com> 38c2ecf20Sopenharmony_ci 48c2ecf20Sopenharmony_ci#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt 58c2ecf20Sopenharmony_ci 68c2ecf20Sopenharmony_ci#include <linux/module.h> 78c2ecf20Sopenharmony_ci#include <linux/kernel.h> 88c2ecf20Sopenharmony_ci#include <linux/livepatch.h> 98c2ecf20Sopenharmony_ci 108c2ecf20Sopenharmony_cistatic int replace; 118c2ecf20Sopenharmony_cimodule_param(replace, int, 0644); 128c2ecf20Sopenharmony_ciMODULE_PARM_DESC(replace, "replace (default=0)"); 138c2ecf20Sopenharmony_ci 148c2ecf20Sopenharmony_ci#include <linux/seq_file.h> 158c2ecf20Sopenharmony_cistatic int livepatch_meminfo_proc_show(struct seq_file *m, void *v) 168c2ecf20Sopenharmony_ci{ 178c2ecf20Sopenharmony_ci seq_printf(m, "%s: %s\n", THIS_MODULE->name, 188c2ecf20Sopenharmony_ci "this has been live patched"); 198c2ecf20Sopenharmony_ci return 0; 208c2ecf20Sopenharmony_ci} 218c2ecf20Sopenharmony_ci 228c2ecf20Sopenharmony_cistatic struct klp_func funcs[] = { 238c2ecf20Sopenharmony_ci { 248c2ecf20Sopenharmony_ci .old_name = "meminfo_proc_show", 258c2ecf20Sopenharmony_ci .new_func = livepatch_meminfo_proc_show, 268c2ecf20Sopenharmony_ci }, {} 278c2ecf20Sopenharmony_ci}; 288c2ecf20Sopenharmony_ci 298c2ecf20Sopenharmony_cistatic struct klp_object objs[] = { 308c2ecf20Sopenharmony_ci { 318c2ecf20Sopenharmony_ci /* name being NULL means vmlinux */ 328c2ecf20Sopenharmony_ci .funcs = funcs, 338c2ecf20Sopenharmony_ci }, {} 348c2ecf20Sopenharmony_ci}; 358c2ecf20Sopenharmony_ci 368c2ecf20Sopenharmony_cistatic struct klp_patch patch = { 378c2ecf20Sopenharmony_ci .mod = THIS_MODULE, 388c2ecf20Sopenharmony_ci .objs = objs, 398c2ecf20Sopenharmony_ci /* set .replace in the init function below for demo purposes */ 408c2ecf20Sopenharmony_ci}; 418c2ecf20Sopenharmony_ci 428c2ecf20Sopenharmony_cistatic int test_klp_atomic_replace_init(void) 438c2ecf20Sopenharmony_ci{ 448c2ecf20Sopenharmony_ci patch.replace = replace; 458c2ecf20Sopenharmony_ci return klp_enable_patch(&patch); 468c2ecf20Sopenharmony_ci} 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_cistatic void test_klp_atomic_replace_exit(void) 498c2ecf20Sopenharmony_ci{ 508c2ecf20Sopenharmony_ci} 518c2ecf20Sopenharmony_ci 528c2ecf20Sopenharmony_cimodule_init(test_klp_atomic_replace_init); 538c2ecf20Sopenharmony_cimodule_exit(test_klp_atomic_replace_exit); 548c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL"); 558c2ecf20Sopenharmony_ciMODULE_INFO(livepatch, "Y"); 568c2ecf20Sopenharmony_ciMODULE_AUTHOR("Joe Lawrence <joe.lawrence@redhat.com>"); 578c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Livepatch test: atomic replace"); 58