summaryrefslogtreecommitdiff
path: root/linux/samples/livepatch
diff options
context:
space:
mode:
authorMichael J. Chudobiak <mjc@avtechpulse.com>2016-04-25 10:00:44 -0400
committerMichael J. Chudobiak <mjc@avtechpulse.com>2016-04-25 10:00:44 -0400
commita1df417e74aa6dae7352dc8cbb0ad471af5b7c69 (patch)
treec34b2311e37ea31db153c90cb8f4570374d05e78 /linux/samples/livepatch
initial Olimex linux tree from Daniel, originally Feb 3, 2016
Diffstat (limited to 'linux/samples/livepatch')
-rw-r--r--linux/samples/livepatch/.built-in.o.cmd1
-rw-r--r--linux/samples/livepatch/Makefile1
-rw-r--r--linux/samples/livepatch/built-in.o1
-rw-r--r--linux/samples/livepatch/livepatch-sample.c91
4 files changed, 94 insertions, 0 deletions
diff --git a/linux/samples/livepatch/.built-in.o.cmd b/linux/samples/livepatch/.built-in.o.cmd
new file mode 100644
index 00000000..e6418f3f
--- /dev/null
+++ b/linux/samples/livepatch/.built-in.o.cmd
@@ -0,0 +1 @@
+cmd_samples/livepatch/built-in.o := rm -f samples/livepatch/built-in.o; arm-linux-gnueabihf-ar rcsD samples/livepatch/built-in.o
diff --git a/linux/samples/livepatch/Makefile b/linux/samples/livepatch/Makefile
new file mode 100644
index 00000000..10319d7e
--- /dev/null
+++ b/linux/samples/livepatch/Makefile
@@ -0,0 +1 @@
+obj-$(CONFIG_SAMPLE_LIVEPATCH) += livepatch-sample.o
diff --git a/linux/samples/livepatch/built-in.o b/linux/samples/livepatch/built-in.o
new file mode 100644
index 00000000..8b277f0d
--- /dev/null
+++ b/linux/samples/livepatch/built-in.o
@@ -0,0 +1 @@
+!<arch>
diff --git a/linux/samples/livepatch/livepatch-sample.c b/linux/samples/livepatch/livepatch-sample.c
new file mode 100644
index 00000000..fb8c8614
--- /dev/null
+++ b/linux/samples/livepatch/livepatch-sample.c
@@ -0,0 +1,91 @@
+/*
+ * livepatch-sample.c - Kernel Live Patching Sample Module
+ *
+ * Copyright (C) 2014 Seth Jennings <sjenning@redhat.com>
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <linux/module.h>
+#include <linux/kernel.h>
+#include <linux/livepatch.h>
+
+/*
+ * This (dumb) live patch overrides the function that prints the
+ * kernel boot cmdline when /proc/cmdline is read.
+ *
+ * Example:
+ *
+ * $ cat /proc/cmdline
+ * <your cmdline>
+ *
+ * $ insmod livepatch-sample.ko
+ * $ cat /proc/cmdline
+ * this has been live patched
+ *
+ * $ echo 0 > /sys/kernel/livepatch/livepatch_sample/enabled
+ * $ cat /proc/cmdline
+ * <your cmdline>
+ */
+
+#include <linux/seq_file.h>
+static int livepatch_cmdline_proc_show(struct seq_file *m, void *v)
+{
+ seq_printf(m, "%s\n", "this has been live patched");
+ return 0;
+}
+
+static struct klp_func funcs[] = {
+ {
+ .old_name = "cmdline_proc_show",
+ .new_func = livepatch_cmdline_proc_show,
+ }, { }
+};
+
+static struct klp_object objs[] = {
+ {
+ /* name being NULL means vmlinux */
+ .funcs = funcs,
+ }, { }
+};
+
+static struct klp_patch patch = {
+ .mod = THIS_MODULE,
+ .objs = objs,
+};
+
+static int livepatch_init(void)
+{
+ int ret;
+
+ ret = klp_register_patch(&patch);
+ if (ret)
+ return ret;
+ ret = klp_enable_patch(&patch);
+ if (ret) {
+ WARN_ON(klp_unregister_patch(&patch));
+ return ret;
+ }
+ return 0;
+}
+
+static void livepatch_exit(void)
+{
+ WARN_ON(klp_disable_patch(&patch));
+ WARN_ON(klp_unregister_patch(&patch));
+}
+
+module_init(livepatch_init);
+module_exit(livepatch_exit);
+MODULE_LICENSE("GPL");