From c72899f6d2270c942e95b4fb4df5458ac8a45294 Mon Sep 17 00:00:00 2001 From: Joe Lawrence Date: Wed, 4 Dec 2024 14:56:40 -0500 Subject: [PATCH] test/integration/rhel-10.0: add kernel-6.12.0-32.el10 tests Signed-off-by: Joe Lawrence --- .../rhel-10.0/data-new-LOADED.test | 3 + test/integration/rhel-10.0/data-new.patch | 20 +++ .../rhel-10.0/gcc-static-local-var-6.patch | 22 +++ .../rhel-10.0/macro-callbacks.patch | 155 ++++++++++++++++++ test/integration/rhel-10.0/module-LOADED.test | 11 ++ test/integration/rhel-10.0/module.patch | 75 +++++++++ test/integration/rhel-10.0/multiple.test | 7 + test/integration/rhel-10.0/new-function.patch | 25 +++ test/integration/rhel-10.0/new-globals.patch | 34 ++++ .../rhel-10.0/shadow-newpid-LOADED.test | 3 + .../integration/rhel-10.0/shadow-newpid.patch | 75 +++++++++ .../rhel-10.0/special-static.patch | 22 +++ .../rhel-10.0/symvers-disagreement-FAIL.patch | 43 +++++ .../integration/rhel-10.0/syscall-LOADED.test | 3 + test/integration/rhel-10.0/syscall.patch | 20 +++ .../rhel-10.0/warn-detect-FAIL.patch | 9 + 16 files changed, 527 insertions(+) create mode 100755 test/integration/rhel-10.0/data-new-LOADED.test create mode 100644 test/integration/rhel-10.0/data-new.patch create mode 100644 test/integration/rhel-10.0/gcc-static-local-var-6.patch create mode 100644 test/integration/rhel-10.0/macro-callbacks.patch create mode 100755 test/integration/rhel-10.0/module-LOADED.test create mode 100644 test/integration/rhel-10.0/module.patch create mode 100755 test/integration/rhel-10.0/multiple.test create mode 100644 test/integration/rhel-10.0/new-function.patch create mode 100644 test/integration/rhel-10.0/new-globals.patch create mode 100755 test/integration/rhel-10.0/shadow-newpid-LOADED.test create mode 100644 test/integration/rhel-10.0/shadow-newpid.patch create mode 100644 test/integration/rhel-10.0/special-static.patch create mode 100644 test/integration/rhel-10.0/symvers-disagreement-FAIL.patch create mode 100755 test/integration/rhel-10.0/syscall-LOADED.test create mode 100644 test/integration/rhel-10.0/syscall.patch create mode 100644 test/integration/rhel-10.0/warn-detect-FAIL.patch diff --git a/test/integration/rhel-10.0/data-new-LOADED.test b/test/integration/rhel-10.0/data-new-LOADED.test new file mode 100755 index 000000000..9f25744e6 --- /dev/null +++ b/test/integration/rhel-10.0/data-new-LOADED.test @@ -0,0 +1,3 @@ +#!/bin/bash + +grep "kpatch: 5" /proc/meminfo diff --git a/test/integration/rhel-10.0/data-new.patch b/test/integration/rhel-10.0/data-new.patch new file mode 100644 index 000000000..a1ba7d3ff --- /dev/null +++ b/test/integration/rhel-10.0/data-new.patch @@ -0,0 +1,20 @@ +diff -Nupr src.orig/fs/proc/meminfo.c src/fs/proc/meminfo.c +--- src.orig/fs/proc/meminfo.c 2024-12-04 14:33:32.491319856 -0500 ++++ src/fs/proc/meminfo.c 2024-12-04 14:33:33.848325829 -0500 +@@ -31,6 +31,8 @@ static void show_val_kb(struct seq_file + seq_write(m, " kB\n", 4); + } + ++static int foo = 5; ++ + static int meminfo_proc_show(struct seq_file *m, void *v) + { + struct sysinfo i; +@@ -157,6 +159,7 @@ static int meminfo_proc_show(struct seq_ + show_val_kb(m, "CmaFree: ", + global_zone_page_state(NR_FREE_CMA_PAGES)); + #endif ++ seq_printf(m, "kpatch: %d\n", foo); + + #ifdef CONFIG_UNACCEPTED_MEMORY + show_val_kb(m, "Unaccepted: ", diff --git a/test/integration/rhel-10.0/gcc-static-local-var-6.patch b/test/integration/rhel-10.0/gcc-static-local-var-6.patch new file mode 100644 index 000000000..ec792880d --- /dev/null +++ b/test/integration/rhel-10.0/gcc-static-local-var-6.patch @@ -0,0 +1,22 @@ +diff -Nupr src.orig/net/ipv6/netfilter.c src/net/ipv6/netfilter.c +--- src.orig/net/ipv6/netfilter.c 2024-12-04 14:33:32.842321401 -0500 ++++ src/net/ipv6/netfilter.c 2024-12-04 14:33:48.370389744 -0500 +@@ -97,6 +97,8 @@ static int nf_ip6_reroute(struct sk_buff + return 0; + } + ++#include "kpatch-macros.h" ++ + int __nf_ip6_route(struct net *net, struct dst_entry **dst, + struct flowi *fl, bool strict) + { +@@ -110,6 +112,9 @@ int __nf_ip6_route(struct net *net, stru + struct dst_entry *result; + int err; + ++ if (!jiffies) ++ printk("kpatch nf_ip6_route foo\n"); ++ + result = ip6_route_output(net, sk, &fl->u.ip6); + err = result->error; + if (err) diff --git a/test/integration/rhel-10.0/macro-callbacks.patch b/test/integration/rhel-10.0/macro-callbacks.patch new file mode 100644 index 000000000..948dde1cf --- /dev/null +++ b/test/integration/rhel-10.0/macro-callbacks.patch @@ -0,0 +1,155 @@ +diff -Nupr src.orig/drivers/input/joydev.c src/drivers/input/joydev.c +--- src.orig/drivers/input/joydev.c 2024-12-04 14:33:31.615316001 -0500 ++++ src/drivers/input/joydev.c 2024-12-04 14:33:52.416407552 -0500 +@@ -1095,3 +1095,47 @@ static void __exit joydev_exit(void) + + module_init(joydev_init); + module_exit(joydev_exit); ++ ++#include ++#include "kpatch-macros.h" ++ ++static const char *const module_state[] = { ++ [MODULE_STATE_LIVE] = "[MODULE_STATE_LIVE] Normal state", ++ [MODULE_STATE_COMING] = "[MODULE_STATE_COMING] Full formed, running module_init", ++ [MODULE_STATE_GOING] = "[MODULE_STATE_GOING] Going away", ++ [MODULE_STATE_UNFORMED] = "[MODULE_STATE_UNFORMED] Still setting it up", ++}; ++ ++static void callback_info(const char *callback, patch_object *obj) ++{ ++ if (obj->mod) ++ pr_info("%s: %s -> %s\n", callback, obj->mod->name, ++ module_state[obj->mod->state]); ++ else ++ pr_info("%s: vmlinux\n", callback); ++} ++ ++static int pre_patch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++ return 0; /* return -ENODEV; */ ++} ++KPATCH_PRE_PATCH_CALLBACK(pre_patch_callback); ++ ++static void post_patch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_POST_PATCH_CALLBACK(post_patch_callback); ++ ++static void pre_unpatch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_PRE_UNPATCH_CALLBACK(pre_unpatch_callback); ++ ++static void post_unpatch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_POST_UNPATCH_CALLBACK(post_unpatch_callback); +diff -Nupr src.orig/drivers/input/misc/pcspkr.c src/drivers/input/misc/pcspkr.c +--- src.orig/drivers/input/misc/pcspkr.c 2024-12-04 14:33:31.621316027 -0500 ++++ src/drivers/input/misc/pcspkr.c 2024-12-04 14:33:52.416407552 -0500 +@@ -132,3 +132,46 @@ static struct platform_driver pcspkr_pla + }; + module_platform_driver(pcspkr_platform_driver); + ++#include ++#include "kpatch-macros.h" ++ ++static const char *const module_state[] = { ++ [MODULE_STATE_LIVE] = "[MODULE_STATE_LIVE] Normal state", ++ [MODULE_STATE_COMING] = "[MODULE_STATE_COMING] Full formed, running module_init", ++ [MODULE_STATE_GOING] = "[MODULE_STATE_GOING] Going away", ++ [MODULE_STATE_UNFORMED] = "[MODULE_STATE_UNFORMED] Still setting it up", ++}; ++ ++static void callback_info(const char *callback, patch_object *obj) ++{ ++ if (obj->mod) ++ pr_info("%s: %s -> %s\n", callback, obj->mod->name, ++ module_state[obj->mod->state]); ++ else ++ pr_info("%s: vmlinux\n", callback); ++} ++ ++static int pre_patch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++ return 0; ++} ++KPATCH_PRE_PATCH_CALLBACK(pre_patch_callback); ++ ++static void post_patch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_POST_PATCH_CALLBACK(post_patch_callback); ++ ++static void pre_unpatch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_PRE_UNPATCH_CALLBACK(pre_unpatch_callback); ++ ++static void post_unpatch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_POST_UNPATCH_CALLBACK(post_unpatch_callback); +diff -Nupr src.orig/fs/aio.c src/fs/aio.c +--- src.orig/fs/aio.c 2024-12-04 14:33:32.430319588 -0500 ++++ src/fs/aio.c 2024-12-04 14:33:52.417407556 -0500 +@@ -50,6 +50,50 @@ + + #define KIOCB_KEY 0 + ++#include ++#include "kpatch-macros.h" ++ ++static const char *const module_state[] = { ++ [MODULE_STATE_LIVE] = "[MODULE_STATE_LIVE] Normal state", ++ [MODULE_STATE_COMING] = "[MODULE_STATE_COMING] Full formed, running module_init", ++ [MODULE_STATE_GOING] = "[MODULE_STATE_GOING] Going away", ++ [MODULE_STATE_UNFORMED] = "[MODULE_STATE_UNFORMED] Still setting it up", ++}; ++ ++static void callback_info(const char *callback, patch_object *obj) ++{ ++ if (obj->mod) ++ pr_info("%s: %s -> %s\n", callback, obj->mod->name, ++ module_state[obj->mod->state]); ++ else ++ pr_info("%s: vmlinux\n", callback); ++} ++ ++static int pre_patch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++ return 0; ++} ++KPATCH_PRE_PATCH_CALLBACK(pre_patch_callback); ++ ++static void post_patch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_POST_PATCH_CALLBACK(post_patch_callback); ++ ++static void pre_unpatch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_PRE_UNPATCH_CALLBACK(pre_unpatch_callback); ++ ++static void post_unpatch_callback(patch_object *obj) ++{ ++ callback_info(__func__, obj); ++} ++KPATCH_POST_UNPATCH_CALLBACK(post_unpatch_callback); ++ + #define AIO_RING_MAGIC 0xa10a10a1 + #define AIO_RING_COMPAT_FEATURES 1 + #define AIO_RING_INCOMPAT_FEATURES 0 diff --git a/test/integration/rhel-10.0/module-LOADED.test b/test/integration/rhel-10.0/module-LOADED.test new file mode 100755 index 000000000..bed43ca52 --- /dev/null +++ b/test/integration/rhel-10.0/module-LOADED.test @@ -0,0 +1,11 @@ +#!/bin/bash + +set -o errexit + +sudo modprobe xfs +sleep 5 +grep -q kpatch /sys/fs/xfs/stats/stats +# TODO: This will trigger a printk on newer kernels which have the .klp.arch +# removal. Don't actually do the grep until running on a newer kernel. +echo "file fs/xfs/xfs_stats.c +p" > /sys/kernel/debug/dynamic_debug/control +# dmesg | grep -q "kpatch: pr_debug" diff --git a/test/integration/rhel-10.0/module.patch b/test/integration/rhel-10.0/module.patch new file mode 100644 index 000000000..8e42a2a85 --- /dev/null +++ b/test/integration/rhel-10.0/module.patch @@ -0,0 +1,75 @@ +kpatch module integration test + +This tests several things related to the patching of modules: + +- 'kpatch_string' tests the referencing of a symbol which is outside the + .o, but inside the patch module. + +- alternatives patching (.altinstructions) + +- paravirt patching (.parainstructions) + +- jump labels (5.8+ kernels only) -- including dynamic printk + +Signed-off-by: Josh Poimboeuf + +diff -Nupr src.orig/fs/xfs/xfs_stats.c src/fs/xfs/xfs_stats.c +--- src.orig/fs/xfs/xfs_stats.c 2024-12-04 14:33:32.517319971 -0500 ++++ src/fs/xfs/xfs_stats.c 2024-12-04 14:33:56.395425064 -0500 +@@ -16,6 +16,8 @@ static int counter_val(struct xfsstats _ + return val; + } + ++extern char *kpatch_string(void); ++ + int xfs_stats_format(struct xfsstats __percpu *stats, char *buf) + { + int i, j; +@@ -87,6 +89,34 @@ int xfs_stats_format(struct xfsstats __p + 0); + #endif + ++ /* Reference a symbol outside the .o yet inside the patch module: */ ++ len += scnprintf(buf + len, PATH_MAX-len, "%s\n", kpatch_string()); ++ ++#ifdef CONFIG_X86_64 ++ /* Test alternatives patching: */ ++ alternative("ud2", "nop", X86_FEATURE_ALWAYS); ++ alternative("nop", "ud2", X86_FEATURE_IA64); ++ ++ /* Test paravirt patching: */ ++ slow_down_io(); /* paravirt call */ ++#endif ++ ++ /* Test pr_debug: */ ++ pr_debug("kpatch: pr_debug() test\n"); ++ ++{ ++ /* Test static branches: */ ++ static DEFINE_STATIC_KEY_TRUE(kpatch_key); ++ ++ if (static_branch_unlikely(&memcg_kmem_online_key)) ++ printk("kpatch: memcg_kmem_online_key\n"); ++ ++ BUG_ON(!static_branch_likely(&kpatch_key)); ++ static_branch_disable(&kpatch_key); ++ BUG_ON(static_branch_likely(&kpatch_key)); ++ static_branch_enable(&kpatch_key); ++} ++ + return len; + } + +diff -Nupr src.orig/net/netlink/af_netlink.c src/net/netlink/af_netlink.c +--- src.orig/net/netlink/af_netlink.c 2024-12-04 14:33:32.863321493 -0500 ++++ src/net/netlink/af_netlink.c 2024-12-04 14:33:56.395425064 -0500 +@@ -2941,4 +2941,9 @@ panic: + panic("netlink_init: Cannot allocate nl_table\n"); + } + ++char *kpatch_string(void) ++{ ++ return "kpatch"; ++} ++ + core_initcall(netlink_proto_init); diff --git a/test/integration/rhel-10.0/multiple.test b/test/integration/rhel-10.0/multiple.test new file mode 100755 index 000000000..7e4b3525c --- /dev/null +++ b/test/integration/rhel-10.0/multiple.test @@ -0,0 +1,7 @@ +#!/bin/bash + +SCRIPTDIR="$(readlink -f $(dirname $(type -p $0)))" + +declare -a blacklist=(meminfo-string-LOADED.test) + +source ${SCRIPTDIR}/../common/multiple.template diff --git a/test/integration/rhel-10.0/new-function.patch b/test/integration/rhel-10.0/new-function.patch new file mode 100644 index 000000000..42eceb32a --- /dev/null +++ b/test/integration/rhel-10.0/new-function.patch @@ -0,0 +1,25 @@ +diff -Nupr src.orig/drivers/tty/n_tty.c src/drivers/tty/n_tty.c +--- src.orig/drivers/tty/n_tty.c 2024-12-04 14:33:32.347319222 -0500 ++++ src/drivers/tty/n_tty.c 2024-12-04 14:34:00.293442220 -0500 +@@ -2355,7 +2355,7 @@ more_to_be_read: + * (note that the process_output*() functions take this lock themselves) + */ + +-static ssize_t n_tty_write(struct tty_struct *tty, struct file *file, ++static ssize_t noinline kpatch_n_tty_write(struct tty_struct *tty, struct file *file, + const u8 *buf, size_t nr) + { + const u8 *b = buf; +@@ -2440,6 +2440,12 @@ break_out: + return (b - buf) ? b - buf : retval; + } + ++static ssize_t __attribute__((optimize("-fno-optimize-sibling-calls"))) n_tty_write(struct tty_struct *tty, struct file *file, ++ const unsigned char *buf, size_t nr) ++{ ++ return kpatch_n_tty_write(tty, file, buf, nr); ++} ++ + /** + * n_tty_poll - poll method for N_TTY + * @tty: terminal device diff --git a/test/integration/rhel-10.0/new-globals.patch b/test/integration/rhel-10.0/new-globals.patch new file mode 100644 index 000000000..5abe7860a --- /dev/null +++ b/test/integration/rhel-10.0/new-globals.patch @@ -0,0 +1,34 @@ +diff -Nupr src.orig/fs/proc/cmdline.c src/fs/proc/cmdline.c +--- src.orig/fs/proc/cmdline.c 2024-12-04 14:33:32.490319852 -0500 ++++ src/fs/proc/cmdline.c 2024-12-04 14:34:04.271459729 -0500 +@@ -22,3 +22,10 @@ static int __init proc_cmdline_init(void + return 0; + } + fs_initcall(proc_cmdline_init); ++ ++#include ++void kpatch_print_message(void) ++{ ++ if (!jiffies) ++ printk("hello there!\n"); ++} +diff -Nupr src.orig/fs/proc/meminfo.c src/fs/proc/meminfo.c +--- src.orig/fs/proc/meminfo.c 2024-12-04 14:33:32.491319856 -0500 ++++ src/fs/proc/meminfo.c 2024-12-04 14:34:04.271459729 -0500 +@@ -21,6 +21,8 @@ + #include + #include "internal.h" + ++void kpatch_print_message(void); ++ + void __attribute__((weak)) arch_report_meminfo(struct seq_file *m) + { + } +@@ -57,6 +59,7 @@ static int meminfo_proc_show(struct seq_ + sreclaimable = global_node_page_state_pages(NR_SLAB_RECLAIMABLE_B); + sunreclaim = global_node_page_state_pages(NR_SLAB_UNRECLAIMABLE_B); + ++ kpatch_print_message(); + show_val_kb(m, "MemTotal: ", i.totalram); + show_val_kb(m, "MemFree: ", i.freeram); + show_val_kb(m, "MemAvailable: ", available); diff --git a/test/integration/rhel-10.0/shadow-newpid-LOADED.test b/test/integration/rhel-10.0/shadow-newpid-LOADED.test new file mode 100755 index 000000000..c07d11205 --- /dev/null +++ b/test/integration/rhel-10.0/shadow-newpid-LOADED.test @@ -0,0 +1,3 @@ +#!/bin/bash + +grep -q newpid: /proc/$$/status diff --git a/test/integration/rhel-10.0/shadow-newpid.patch b/test/integration/rhel-10.0/shadow-newpid.patch new file mode 100644 index 000000000..dc72625a1 --- /dev/null +++ b/test/integration/rhel-10.0/shadow-newpid.patch @@ -0,0 +1,75 @@ +diff -Nupr src.orig/fs/proc/array.c src/fs/proc/array.c +--- src.orig/fs/proc/array.c 2024-12-04 14:33:32.490319852 -0500 ++++ src/fs/proc/array.c 2024-12-04 14:34:08.196477004 -0500 +@@ -395,12 +395,19 @@ static inline void task_seccomp(struct s + seq_putc(m, '\n'); + } + ++#include + static inline void task_context_switch_counts(struct seq_file *m, + struct task_struct *p) + { ++ int *newpid; ++ + seq_put_decimal_ull(m, "voluntary_ctxt_switches:\t", p->nvcsw); + seq_put_decimal_ull(m, "\nnonvoluntary_ctxt_switches:\t", p->nivcsw); + seq_putc(m, '\n'); ++ ++ newpid = klp_shadow_get(p, 0); ++ if (newpid) ++ seq_printf(m, "newpid:\t%d\n", *newpid); + } + + static void task_cpus_allowed(struct seq_file *m, struct task_struct *task) +diff -Nupr src.orig/kernel/exit.c src/kernel/exit.c +--- src.orig/kernel/exit.c 2024-12-04 14:33:32.762321049 -0500 ++++ src/kernel/exit.c 2024-12-04 14:34:08.197477008 -0500 +@@ -874,6 +874,7 @@ static void synchronize_group_exit(struc + spin_unlock_irq(&sighand->siglock); + } + ++#include + void __noreturn do_exit(long code) + { + struct task_struct *tsk = current; +@@ -939,6 +940,8 @@ void __noreturn do_exit(long code) + exit_task_work(tsk); + exit_thread(tsk); + ++ klp_shadow_free(tsk, 0, NULL); ++ + /* + * Flush inherited counters to the parent - before the parent + * gets woken up by child-exit notifications. +diff -Nupr src.orig/kernel/fork.c src/kernel/fork.c +--- src.orig/kernel/fork.c 2024-12-04 14:33:32.762321049 -0500 ++++ src/kernel/fork.c 2024-12-04 14:34:08.198477013 -0500 +@@ -2742,6 +2742,7 @@ struct task_struct *create_io_thread(int + * + * args->exit_signal is expected to be checked for sanity by the caller. + */ ++#include + pid_t kernel_clone(struct kernel_clone_args *args) + { + u64 clone_flags = args->flags; +@@ -2750,6 +2751,8 @@ pid_t kernel_clone(struct kernel_clone_a + struct task_struct *p; + int trace = 0; + pid_t nr; ++ int *newpid; ++ static int ctr = 0; + + /* + * For legacy clone() calls, CLONE_PIDFD uses the parent_tid argument +@@ -2789,6 +2792,11 @@ pid_t kernel_clone(struct kernel_clone_a + if (IS_ERR(p)) + return PTR_ERR(p); + ++ newpid = klp_shadow_get_or_alloc(p, 0, sizeof(*newpid), GFP_KERNEL, ++ NULL, NULL); ++ if (newpid) ++ *newpid = ctr++; ++ + /* + * Do this prior waking up the new thread - the thread pointer + * might get invalid after that point, if the thread exits quickly. diff --git a/test/integration/rhel-10.0/special-static.patch b/test/integration/rhel-10.0/special-static.patch new file mode 100644 index 000000000..7fba74148 --- /dev/null +++ b/test/integration/rhel-10.0/special-static.patch @@ -0,0 +1,22 @@ +diff -Nupr src.orig/kernel/fork.c src/kernel/fork.c +--- src.orig/kernel/fork.c 2024-12-04 14:33:32.762321049 -0500 ++++ src/kernel/fork.c 2024-12-04 14:34:12.103494200 -0500 +@@ -1832,10 +1832,18 @@ static void posix_cpu_timers_init_group( + posix_cputimers_group_init(pct, cpu_limit); + } + ++void kpatch_foo(void) ++{ ++ if (!jiffies) ++ printk("kpatch copy signal\n"); ++} ++ + static int copy_signal(unsigned long clone_flags, struct task_struct *tsk) + { + struct signal_struct *sig; + ++ kpatch_foo(); ++ + if (clone_flags & CLONE_THREAD) + return 0; + diff --git a/test/integration/rhel-10.0/symvers-disagreement-FAIL.patch b/test/integration/rhel-10.0/symvers-disagreement-FAIL.patch new file mode 100644 index 000000000..3039a1aff --- /dev/null +++ b/test/integration/rhel-10.0/symvers-disagreement-FAIL.patch @@ -0,0 +1,43 @@ +From 2d6b7bce089e52563bd9c67df62f48e90b48047d Mon Sep 17 00:00:00 2001 +From: Julien Thierry +Date: Wed, 6 May 2020 14:30:57 +0100 +Subject: [PATCH] Symbol version change + +This change causes: +1) Some exported symbols in drivers/base/core.c to see their CRCs + change. +2) Changes usb_get_dev() referencing a get_device() whose CRC has + changed, causing the symbol and the new CRC to be included in the + __version section of the final module. + +This makes the final module unloadable for the target kernel. + +See "Exported symbol versioning" of the patch author guide for more +detail. + +--- + +diff -Nupr src.orig/drivers/base/core.c src/drivers/base/core.c +--- src.orig/drivers/base/core.c 2024-12-04 14:33:31.099313730 -0500 ++++ src/drivers/base/core.c 2024-12-04 14:34:16.029511479 -0500 +@@ -37,6 +37,8 @@ + #include "physical_location.h" + #include "power/power.h" + ++#include ++ + /* Device links support. */ + static LIST_HEAD(deferred_sync); + static unsigned int defer_sync_state_count = 1; +diff -Nupr src.orig/drivers/usb/core/usb.c src/drivers/usb/core/usb.c +--- src.orig/drivers/usb/core/usb.c 2024-12-04 14:33:32.360319280 -0500 ++++ src/drivers/usb/core/usb.c 2024-12-04 14:34:16.030511483 -0500 +@@ -761,6 +761,8 @@ EXPORT_SYMBOL_GPL(usb_alloc_dev); + */ + struct usb_device *usb_get_dev(struct usb_device *dev) + { ++ barrier(); ++ + if (dev) + get_device(&dev->dev); + return dev; diff --git a/test/integration/rhel-10.0/syscall-LOADED.test b/test/integration/rhel-10.0/syscall-LOADED.test new file mode 100755 index 000000000..3a2fd88e0 --- /dev/null +++ b/test/integration/rhel-10.0/syscall-LOADED.test @@ -0,0 +1,3 @@ +#!/bin/bash + +uname -s | grep -q kpatch diff --git a/test/integration/rhel-10.0/syscall.patch b/test/integration/rhel-10.0/syscall.patch new file mode 100644 index 000000000..deb155db8 --- /dev/null +++ b/test/integration/rhel-10.0/syscall.patch @@ -0,0 +1,20 @@ +diff -Nupr src.orig/kernel/sys.c src/kernel/sys.c +--- src.orig/kernel/sys.c 2024-12-04 14:33:32.771321088 -0500 ++++ src/kernel/sys.c 2024-12-04 14:34:19.937528679 -0500 +@@ -1312,13 +1312,15 @@ static int override_release(char __user + return ret; + } + +-SYSCALL_DEFINE1(newuname, struct new_utsname __user *, name) ++#include "kpatch-syscall.h" ++KPATCH_SYSCALL_DEFINE1(newuname, struct new_utsname __user *, name) + { + struct new_utsname tmp; + + down_read(&uts_sem); + memcpy(&tmp, utsname(), sizeof(tmp)); + up_read(&uts_sem); ++ strcat(tmp.sysname, ".kpatch"); + if (copy_to_user(name, &tmp, sizeof(tmp))) + return -EFAULT; + diff --git a/test/integration/rhel-10.0/warn-detect-FAIL.patch b/test/integration/rhel-10.0/warn-detect-FAIL.patch new file mode 100644 index 000000000..a5d7bf13f --- /dev/null +++ b/test/integration/rhel-10.0/warn-detect-FAIL.patch @@ -0,0 +1,9 @@ +diff -Nupr src.orig/arch/x86/kvm/x86.c src/arch/x86/kvm/x86.c +--- src.orig/arch/x86/kvm/x86.c 2024-12-04 14:33:31.024313399 -0500 ++++ src/arch/x86/kvm/x86.c 2024-12-04 14:34:23.844545875 -0500 +@@ -1,4 +1,5 @@ + // SPDX-License-Identifier: GPL-2.0-only ++ + /* + * Kernel-based Virtual Machine driver for Linux + *