Blame view
samples/livepatch/livepatch-callbacks-busymod.c
1.34 KB
1ccea77e2 treewide: Replace... |
1 |
// SPDX-License-Identifier: GPL-2.0-or-later |
93862e385 livepatch: add (u... |
2 3 |
/* * Copyright (C) 2017 Joe Lawrence <joe.lawrence@redhat.com> |
93862e385 livepatch: add (u... |
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 |
*/ /* * livepatch-callbacks-busymod.c - (un)patching callbacks demo support module * * * Purpose * ------- * * Simple module to demonstrate livepatch (un)patching callbacks. * * * Usage * ----- * * This module is not intended to be standalone. See the "Usage" * section of livepatch-callbacks-mod.c. */ #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt #include <linux/module.h> #include <linux/kernel.h> #include <linux/workqueue.h> #include <linux/delay.h> static int sleep_secs; module_param(sleep_secs, int, 0644); MODULE_PARM_DESC(sleep_secs, "sleep_secs (default=0)"); static void busymod_work_func(struct work_struct *work); static DECLARE_DELAYED_WORK(work, busymod_work_func); static void busymod_work_func(struct work_struct *work) { pr_info("%s, sleeping %d seconds ... ", __func__, sleep_secs); msleep(sleep_secs * 1000); pr_info("%s exit ", __func__); } static int livepatch_callbacks_mod_init(void) { pr_info("%s ", __func__); schedule_delayed_work(&work, msecs_to_jiffies(1000 * 0)); return 0; } static void livepatch_callbacks_mod_exit(void) { cancel_delayed_work_sync(&work); pr_info("%s ", __func__); } module_init(livepatch_callbacks_mod_init); module_exit(livepatch_callbacks_mod_exit); MODULE_LICENSE("GPL"); |