Sync from SUSE:SLFO:Kernel:1.0 kernel-livepatch-MICRO-6-0-RT_Update_4 revision 4977b5305c63e7782a05a345bb66b4c7
This commit is contained in:
commit
8360437fc7
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
## Default LFS
|
||||
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||
*.png filter=lfs diff=lfs merge=lfs -text
|
||||
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||
*.zst filter=lfs diff=lfs merge=lfs -text
|
14
Makefile
Normal file
14
Makefile
Normal file
@ -0,0 +1,14 @@
|
||||
KDIR ?= /lib/modules/`uname -r`/build
|
||||
|
||||
ccflags-y += -I$(obj)
|
||||
|
||||
obj-m := livepatch-@@RPMRELEASE@@.o
|
||||
|
||||
livepatch-@@RPMRELEASE@@-y := kallsyms_relocs.o livepatch_main.o uname_patch/livepatch_uname.o
|
||||
|
||||
default:
|
||||
$(MAKE) -C $(KDIR) M=$(CURDIR) modules
|
||||
|
||||
clean:
|
||||
$(MAKE) -C $(KDIR) M=$(CURDIR) clean
|
||||
|
129
kallsyms_relocs.c
Normal file
129
kallsyms_relocs.c
Normal file
@ -0,0 +1,129 @@
|
||||
/*
|
||||
* kallsyms_relocs.c - resolve non-exported symbols
|
||||
*
|
||||
* Copyright (C) 2018 SUSE
|
||||
* Author: Nicolai Stange <nstange@suse.de>
|
||||
*
|
||||
* 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/kernel.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/kallsyms.h>
|
||||
#include "kallsyms_relocs.h"
|
||||
|
||||
struct find_args
|
||||
{
|
||||
struct klp_kallsyms_reloc reloc;
|
||||
unsigned long match_count;
|
||||
};
|
||||
|
||||
static int __find_callback(void *data, const char *name, unsigned long addr)
|
||||
{
|
||||
struct find_args *args = data;
|
||||
|
||||
if (strcmp(args->reloc.symname, name))
|
||||
return 0;
|
||||
|
||||
args->match_count++;
|
||||
|
||||
/*
|
||||
* Finish the search when the symbol is found for the desired
|
||||
* position or the position is not defined.
|
||||
*/
|
||||
if (!args->reloc.sympos || args->match_count == args->reloc.sympos) {
|
||||
*args->reloc.addr = (void *)addr;
|
||||
return 1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static
|
||||
int (*klpe_module_kallsyms_on_each_symbol)(const char *modname,
|
||||
int (*fn)(void *, const char *,
|
||||
unsigned long),
|
||||
void *data);
|
||||
|
||||
static int __klp_resolve_kallsyms_relocs(struct klp_kallsyms_reloc *relocs,
|
||||
unsigned long count)
|
||||
{
|
||||
unsigned long i;
|
||||
struct find_args args;
|
||||
|
||||
for (i = 0; i < count; ++i) {
|
||||
*relocs[i].addr = NULL;
|
||||
args.reloc = relocs[i];
|
||||
args.match_count = 0;
|
||||
|
||||
if (args.reloc.objname) {
|
||||
klpe_module_kallsyms_on_each_symbol(args.reloc.objname,
|
||||
__find_callback,
|
||||
&args);
|
||||
} else {
|
||||
kallsyms_on_each_symbol(__find_callback, &args);
|
||||
}
|
||||
|
||||
if (!*relocs[i].addr) {
|
||||
if (relocs[i].objname) {
|
||||
pr_err("livepatch: symbol %s:%s not resolved\n",
|
||||
relocs[i].objname, relocs[i].symname);
|
||||
} else {
|
||||
pr_err("livepatch: symbol %s not resolved\n",
|
||||
relocs[i].symname);
|
||||
}
|
||||
|
||||
return -ENOENT;
|
||||
}
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
struct module *(*klpe_find_module)(const char *name);
|
||||
|
||||
/* Bootstrap: resolve non-exported module_kallsyms_on_each_symbol() */
|
||||
int klp_kallsyms_relocs_init(void)
|
||||
{
|
||||
static struct klp_kallsyms_reloc bootstrap_relocs[] = {
|
||||
{ "module_kallsyms_on_each_symbol",
|
||||
(void *)&klpe_module_kallsyms_on_each_symbol },
|
||||
{ "find_module", (void *)&klpe_find_module },
|
||||
};
|
||||
|
||||
/* Already initialized? */
|
||||
if (klpe_module_kallsyms_on_each_symbol)
|
||||
return 0;
|
||||
|
||||
/*
|
||||
* All relocations are against symbols from vmlinux, the yet
|
||||
* unresolved klpe_module_kallsyms_on_each_symbol() will not
|
||||
* get invoked and the call below will work fine at this stage
|
||||
* already.
|
||||
*/
|
||||
return __klp_resolve_kallsyms_relocs(bootstrap_relocs,
|
||||
ARRAY_SIZE(bootstrap_relocs));
|
||||
}
|
||||
|
||||
int klp_resolve_kallsyms_relocs(struct klp_kallsyms_reloc *relocs,
|
||||
unsigned long count)
|
||||
{
|
||||
int ret;
|
||||
|
||||
ret = klp_kallsyms_relocs_init();
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
return __klp_resolve_kallsyms_relocs(relocs, count);
|
||||
}
|
19
kallsyms_relocs.h
Normal file
19
kallsyms_relocs.h
Normal file
@ -0,0 +1,19 @@
|
||||
#ifndef _KLP_KALLSYMS_RELOCS
|
||||
#define _KLP_KALLSYMS_RELOCS
|
||||
|
||||
struct klp_kallsyms_reloc
|
||||
{
|
||||
const char *symname;
|
||||
void **addr;
|
||||
const char *objname;
|
||||
unsigned long sympos;
|
||||
};
|
||||
|
||||
int klp_kallsyms_relocs_init(void);
|
||||
|
||||
int klp_resolve_kallsyms_relocs(struct klp_kallsyms_reloc *relocs,
|
||||
unsigned long count);
|
||||
|
||||
extern struct module *(*klpe_find_module)(const char *name);
|
||||
|
||||
#endif /* _KLP_KALLSYMS_RELOCS */
|
1111
kernel-livepatch-MICRO-6-0-RT_Update_4.changes
Normal file
1111
kernel-livepatch-MICRO-6-0-RT_Update_4.changes
Normal file
File diff suppressed because it is too large
Load Diff
101
kernel-livepatch-MICRO-6-0-RT_Update_4.spec
Normal file
101
kernel-livepatch-MICRO-6-0-RT_Update_4.spec
Normal file
@ -0,0 +1,101 @@
|
||||
#
|
||||
# spec file for package Kernel live patch module
|
||||
#
|
||||
# Copyright (c) 2014 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
# upon. The license for this file, and modifications and additions to the
|
||||
# file, is the same license as for the pristine package itself (unless the
|
||||
# license for the pristine package is not an Open Source License, in which
|
||||
# case the license is the MIT License). An "Open Source License" is a
|
||||
# license that conforms to the Open Source Definition (Version 1.9)
|
||||
# published by the Open Source Initiative.
|
||||
|
||||
# Please submit bugfixes or comments via http://bugs.opensuse.org/
|
||||
#
|
||||
|
||||
# needssslcertforbuild
|
||||
|
||||
%define variant -rt%{nil}
|
||||
|
||||
|
||||
Name: kernel-livepatch-MICRO-6-0-RT_Update_4
|
||||
Version: 1
|
||||
Release: 1
|
||||
%define module_num %(echo %version-%release | sed 'y/\./_/')
|
||||
License: GPL-2.0
|
||||
Summary: Kernel live patch module
|
||||
Group: System/Kernel
|
||||
Source0: uname_patch.tar.bz2
|
||||
Source1: Makefile
|
||||
Source2: livepatch_main.c
|
||||
Source3: config.sh
|
||||
Source4: source-timestamp
|
||||
Source5: shadow.h
|
||||
Source6: kallsyms_relocs.h
|
||||
Source7: kallsyms_relocs.c
|
||||
Source8: klp_convert.h
|
||||
Source9: klp_syscalls.h
|
||||
Source10: klp_trace.h
|
||||
# Auto expanded KLP_PATCHES_SOURCES:
|
||||
|
||||
BuildRequires: kernel-syms%{variant} kernel-livepatch-tools-devel libelf-devel
|
||||
%if 0%{?use_klp_convert}
|
||||
%if "%{?variant}"
|
||||
BuildRequires: kernel%{variant}-livepatch-devel
|
||||
%else
|
||||
BuildRequires: kernel-default-livepatch-devel
|
||||
%endif
|
||||
%endif
|
||||
ExclusiveArch: x86_64
|
||||
%klp_module_package
|
||||
|
||||
%description
|
||||
This is a live patch for SUSE Linux Enterprise Server kernel.
|
||||
|
||||
Source timestamp: 2024-11-11 13:14:02 +0100
|
||||
GIT Revision: 22a99cfda2ebc0ca5920050d767cd88c2a573cc1
|
||||
GIT Branch: MICRO-6-0-RT_Update_4
|
||||
|
||||
%prep
|
||||
%setup -c
|
||||
# Auto expanded KLP_PATCHES_SETUP_SOURCES:
|
||||
|
||||
cp %_sourcedir/livepatch_main.c .
|
||||
cp %_sourcedir/shadow.h .
|
||||
cp %_sourcedir/kallsyms_relocs.h .
|
||||
cp %_sourcedir/kallsyms_relocs.c .
|
||||
cp %_sourcedir/Makefile .
|
||||
cp %_sourcedir/klp_convert.h .
|
||||
cp %_sourcedir/klp_syscalls.h .
|
||||
cp %_sourcedir/klp_trace.h .
|
||||
|
||||
%build
|
||||
sed -i 's/@@RPMRELEASE@@/%module_num/g' Makefile
|
||||
sed -i 's/@@RPMRELEASE@@/%module_num/g' livepatch_main.c
|
||||
echo 'livepatch-%module_num' >Module.supported
|
||||
set -- *
|
||||
|
||||
for flavor in %flavors_to_build; do
|
||||
mkdir -p "obj/$flavor"
|
||||
cp -r "$@" "obj/$flavor"
|
||||
make -C %{kernel_source $flavor} M="$PWD/obj/$flavor" modules
|
||||
|
||||
%if 0%{?use_klp_convert}
|
||||
module=$(find "obj/$flavor" -name 'livepatch*.ko' -printf '%f')
|
||||
klp-convert /usr/src/linux-obj/%_target_cpu/$flavor/Symbols.list \
|
||||
obj/$flavor/$module obj/$flavor/${module}_converted
|
||||
mv obj/$flavor/${module}_converted obj/$flavor/$module
|
||||
%endif
|
||||
done
|
||||
|
||||
%install
|
||||
export INSTALL_MOD_DIR=livepatch
|
||||
export INSTALL_MOD_PATH=%buildroot
|
||||
for flavor in %flavors_to_build; do
|
||||
make -C %{kernel_source $flavor} M="$PWD/obj/$flavor" modules_install
|
||||
done
|
||||
|
||||
%changelog
|
||||
|
16
klp_convert.h
Normal file
16
klp_convert.h
Normal file
@ -0,0 +1,16 @@
|
||||
#ifndef _KLP_KLPCONVERT_H
|
||||
#define _KLP_KLPCONVERT_H
|
||||
|
||||
#ifdef USE_KLP_CONVERT
|
||||
|
||||
#define KLP_SYM_LINKAGE extern
|
||||
#define KLP_SYM(sym) sym
|
||||
|
||||
#else
|
||||
|
||||
#define KLP_SYM_LINKAGE static
|
||||
#define KLP_SYM(sym) (*klp_##sym)
|
||||
|
||||
#endif
|
||||
|
||||
#endif
|
111
klp_syscalls.h
Normal file
111
klp_syscalls.h
Normal file
@ -0,0 +1,111 @@
|
||||
#ifndef _KLP_SYSCALLS_H
|
||||
#define _KLP_SYSCALLS_H
|
||||
|
||||
#include <linux/version.h>
|
||||
#include <linux/syscalls.h>
|
||||
|
||||
/*
|
||||
* For kernels after 4.17.0, syscalls' symbol names as constructed by
|
||||
* the kernel's __SYSCALL_DEFINEx macro depend on kernel version and
|
||||
* architecture.
|
||||
*/
|
||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 17, 0)
|
||||
/* C.f. include/linux/syscalls.h */
|
||||
#define KLP_SYSCALL_SYM(name) SyS_ ## name
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
/* What comes out of COMPAT_SYSCALL_DEFINEx(). */
|
||||
#define KLP_COMPAT_SYSCALL_SYM(name) compat_SyS_ ## name
|
||||
|
||||
#define KLP_SYSCALL_DECLx(x, sym, ...) \
|
||||
asmlinkage long sym(__MAP(x,__SC_LONG,__VA_ARGS__))
|
||||
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
|
||||
#else /* LINUX_VERSION_CODE < KERNEL_VERSION(4, 17, 0) */
|
||||
|
||||
|
||||
#if defined(CONFIG_X86_64)
|
||||
/* C.f. arch/x86/include/asm/syscall_wrapper.h */
|
||||
#define KLP_SYSCALL_SYM(name) __x64_sys_ ## name
|
||||
|
||||
#ifdef CONFIG_IA32_EMULATION
|
||||
#define KLP_ARCH_HAS_SYSCALL_COMPAT_STUBS 1
|
||||
/* Compat stub for common syscalls. */
|
||||
#define KLP_SYSCALL_COMPAT_STUB_SYM(name) __ia32_sys_ ## name
|
||||
#endif /* CONFIG_IA32_EMULATION */
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
/* What comes out of COMPAT_SYSCALL_DEFINEx(). */
|
||||
#define KLP_COMPAT_SYSCALL_SYM(name) __ia32_compat_sys_ ## name
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
#define KLP_SYSCALL_DECLx(x, sym, ...) \
|
||||
asmlinkage long sym(const struct pt_regs *)
|
||||
|
||||
|
||||
#elif defined(CONFIG_S390)
|
||||
/* C.f. arch/s390/include/asm/syscall_wrapper.h */
|
||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(6, 3, 0)
|
||||
#define KLP_SYSCALL_SYM(name) __se_sys_ ## name
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
#define KLP_ARCH_HAS_SYSCALL_COMPAT_STUBS 1
|
||||
/* Compat stub for common syscalls. */
|
||||
#define KLP_SYSCALL_COMPAT_STUB_SYM(name) __s390_sys_ ## name
|
||||
#define KLP_COMPAT_SYSCALL_SYM(name) __se_compat_sys_ ## name
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
#else /* LINUX_VERSION_CODE < KERNEL_VERSION(6, 3, 0) */
|
||||
#define KLP_SYSCALL_SYM(name) __s390x_sys_ ## name
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
#define KLP_ARCH_HAS_SYSCALL_COMPAT_STUBS 1
|
||||
/* Compat stub for common syscalls. */
|
||||
#define KLP_SYSCALL_COMPAT_STUB_SYM(name) __s390_sys_ ## name
|
||||
#define KLP_COMPAT_SYSCALL_SYM(name) __s390_compat_sys_ ## name
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(6, 3, 0) */
|
||||
|
||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 12, 0)
|
||||
#define KLP_SYSCALL_DECLx(x, sym, ...) \
|
||||
asmlinkage long sym(__MAP(x,__SC_LONG,__VA_ARGS__))
|
||||
#else
|
||||
#define KLP_SYSCALL_DECLx(x, sym, ...) \
|
||||
long sym(struct pt_regs *regs)
|
||||
#endif
|
||||
|
||||
#elif defined(CONFIG_PPC64)
|
||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(6, 1, 0)
|
||||
/* C.f. include/linux/syscalls.h */
|
||||
#define KLP_SYSCALL_SYM(name) __se_sys_ ## name
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
#define KLP_COMPAT_SYSCALL_SYM(name) __se_compat_sys_ ## name
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
#define KLP_SYSCALL_DECLx(x, sym, ...) \
|
||||
asmlinkage long sym(__MAP(x,__SC_LONG,__VA_ARGS__))
|
||||
|
||||
#else /* LINUX_VERSION_CODE < KERNEL_VERSION(6, 1, 0) */
|
||||
/* C.f. arch/powerpc/include/asm/syscalls_wrapper.h */
|
||||
#define KLP_SYSCALL_SYM(name) sys_ ## name
|
||||
|
||||
#ifdef CONFIG_COMPAT
|
||||
/* C.f. include/linux/compat.h */
|
||||
#define KLP_COMPAT_SYSCALL_SYM(name) __se_compat_sys_ ## name
|
||||
#endif /* CONFIG_COMPAT */
|
||||
|
||||
#define KLP_SYSCALL_DECLx(x, sym, ...) \
|
||||
long sym(const struct pt_regs *regs)
|
||||
|
||||
#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(6, 1, 0) */
|
||||
|
||||
#else
|
||||
#error "Architecture not supported."
|
||||
#endif
|
||||
|
||||
#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(4, 17, 0) */
|
||||
#endif /* _KLP_SYSCALLS_H */
|
101
klp_trace.h
Normal file
101
klp_trace.h
Normal file
@ -0,0 +1,101 @@
|
||||
#ifndef _KLP_TRACE_H
|
||||
#define _KLP_TRACE_H
|
||||
|
||||
#include <linux/tracepoint.h>
|
||||
#include <linux/version.h>
|
||||
|
||||
/*
|
||||
* Since kernel 5.12, the data_args was removed from __DECLARE_TRACE.
|
||||
* Since kernel 5.10, the __tracepoint_iter_ symbols were renamed to
|
||||
* __traceiter_ in order to have shorter symbol names.
|
||||
* As we currently support kernels from 5.3 and then 5.14, we don't need special
|
||||
* ifdefery for kernel 5.10.
|
||||
*/
|
||||
|
||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(5, 12, 0)
|
||||
#define KLPR___DECLARE_TRACE(name, proto, args, cond, data_proto, data_args) \
|
||||
static struct tracepoint (*klpe___tracepoint_##name); \
|
||||
static inline void klpr_trace_##name(proto) \
|
||||
{ \
|
||||
if (unlikely(static_key_enabled(&(*klpe___tracepoint_##name).key))) \
|
||||
__DO_TRACE(&(*klpe___tracepoint_##name), \
|
||||
TP_PROTO(data_proto), \
|
||||
TP_ARGS(data_args), \
|
||||
TP_CONDITION(cond), 0); \
|
||||
if (IS_ENABLED(CONFIG_LOCKDEP) && (cond)) { \
|
||||
rcu_read_lock_sched_notrace(); \
|
||||
rcu_dereference_sched((*klpe___tracepoint_##name).funcs); \
|
||||
rcu_read_unlock_sched_notrace(); \
|
||||
} \
|
||||
} \
|
||||
|
||||
#define KLPR_DECLARE_TRACE(name, proto, args) \
|
||||
KLPR___DECLARE_TRACE(name, PARAMS(proto), PARAMS(args), \
|
||||
cpu_online(raw_smp_processor_id()), \
|
||||
PARAMS(void *__data, proto), \
|
||||
PARAMS(__data, args))
|
||||
|
||||
#else /* LINUX_VERSION_CODE < KERNEL_VERSION(5, 12, 0) */
|
||||
|
||||
#define KLPR___DO_TRACE_CALL(name, args) (*klpe___traceiter_##name)(NULL, args)
|
||||
|
||||
#define KLPR___DO_TRACE(name, args, cond, rcuidle) \
|
||||
do { \
|
||||
int __maybe_unused __idx = 0; \
|
||||
\
|
||||
if (!(cond)) \
|
||||
return; \
|
||||
\
|
||||
/* srcu can't be used from NMI */ \
|
||||
WARN_ON_ONCE(rcuidle && in_nmi()); \
|
||||
\
|
||||
/* keep srcu and sched-rcu usage consistent */ \
|
||||
preempt_disable_notrace(); \
|
||||
\
|
||||
/* \
|
||||
* For rcuidle callers, use srcu since sched-rcu \
|
||||
* doesn't work from the idle path. \
|
||||
*/ \
|
||||
if (rcuidle) { \
|
||||
__idx = srcu_read_lock_notrace(&tracepoint_srcu);\
|
||||
rcu_irq_enter_irqson(); \
|
||||
} \
|
||||
\
|
||||
KLPR___DO_TRACE_CALL(name, TP_ARGS(args)); \
|
||||
\
|
||||
if (rcuidle) { \
|
||||
rcu_irq_exit_irqson(); \
|
||||
srcu_read_unlock_notrace(&tracepoint_srcu, __idx);\
|
||||
} \
|
||||
\
|
||||
preempt_enable_notrace(); \
|
||||
} while (0)
|
||||
|
||||
#define KLPR___DECLARE_TRACE(name, proto, args, cond, data_proto) \
|
||||
static int (*klpe___traceiter_##name)(data_proto); \
|
||||
static struct tracepoint (*klpe___tracepoint_##name); \
|
||||
static inline void klpr_trace_##name(proto) \
|
||||
{ \
|
||||
if (static_key_enabled(&(*klpe___tracepoint_##name).key)) \
|
||||
KLPR___DO_TRACE(name, \
|
||||
TP_ARGS(args), \
|
||||
TP_CONDITION(cond), 0); \
|
||||
if (IS_ENABLED(CONFIG_LOCKDEP) && (cond)) { \
|
||||
rcu_read_lock_sched_notrace(); \
|
||||
rcu_dereference_sched((*klpe___tracepoint_##name).funcs);\
|
||||
rcu_read_unlock_sched_notrace(); \
|
||||
} \
|
||||
} \
|
||||
|
||||
|
||||
#define KLPR_DECLARE_TRACE(name, proto, args) \
|
||||
KLPR___DECLARE_TRACE(name, PARAMS(proto), PARAMS(args), \
|
||||
cpu_online(raw_smp_processor_id()), \
|
||||
PARAMS(void *__data, proto))
|
||||
|
||||
#endif /* LINUX_VERSION_CODE < KERNEL_VERSION(5, 12, 0) */
|
||||
|
||||
#define KLPR_TRACE_EVENT(name, proto, args) \
|
||||
KLPR_DECLARE_TRACE(name, PARAMS(proto), PARAMS(args))
|
||||
|
||||
#endif /* _KLP_TRACE_H */
|
92
livepatch_main.c
Normal file
92
livepatch_main.c
Normal file
@ -0,0 +1,92 @@
|
||||
/*
|
||||
* livepatch_main.c - kernel live patch main infrastructure
|
||||
*
|
||||
* Copyright (c) 2014 SUSE
|
||||
* Author: Miroslav Benes <mbenes@suse.cz>
|
||||
*
|
||||
* 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/livepatch.h>
|
||||
#include <linux/module.h>
|
||||
#include <linux/types.h>
|
||||
|
||||
#include "uname_patch/livepatch_uname.h"
|
||||
|
||||
/* Auto expanded KLP_PATCHES_INCLUDES: */
|
||||
|
||||
|
||||
static struct klp_object objs[] = {
|
||||
/* Auto expanded KLP_PATCHES_OBJS: */
|
||||
{
|
||||
.name = NULL,
|
||||
.funcs = (struct klp_func[]) {
|
||||
{
|
||||
.old_name = __stringify(KLP_SYSCALL_SYM(newuname)),
|
||||
.new_func = KLP_SYSCALL_SYM(klp_newuname),
|
||||
},
|
||||
#ifdef KLP_ARCH_HAS_SYSCALL_COMPAT_STUBS
|
||||
{
|
||||
.old_name = __stringify(KLP_SYSCALL_COMPAT_STUB_SYM(newuname)),
|
||||
.new_func = KLP_SYSCALL_COMPAT_STUB_SYM(klp_newuname),
|
||||
},
|
||||
#endif
|
||||
{ }
|
||||
}
|
||||
},
|
||||
{ }
|
||||
};
|
||||
|
||||
static struct klp_patch patch = {
|
||||
.mod = THIS_MODULE,
|
||||
.objs = objs,
|
||||
.replace = true,
|
||||
};
|
||||
|
||||
static int __init klp_patch_init(void)
|
||||
{
|
||||
int retval;
|
||||
|
||||
pr_info("livepatch: initializing\n");
|
||||
|
||||
retval = klp_patch_uname_init();
|
||||
if (retval)
|
||||
return retval;
|
||||
|
||||
/* Auto expanded KLP_PATCHES_INIT_CALLS: */
|
||||
|
||||
|
||||
retval = klp_enable_patch(&patch);
|
||||
if (!retval)
|
||||
return retval;
|
||||
|
||||
/* Auto expanded KLP_PATCHES_INIT_ERR_HANDLERS: */
|
||||
|
||||
return retval;
|
||||
}
|
||||
|
||||
static void __exit klp_patch_cleanup(void)
|
||||
{
|
||||
pr_info("livepatch: removed\n");
|
||||
|
||||
/* Auto expanded KLP_PATCHES_CLEANUP_CALLS: */
|
||||
|
||||
}
|
||||
|
||||
module_init(klp_patch_init);
|
||||
module_exit(klp_patch_cleanup);
|
||||
|
||||
MODULE_LICENSE("GPL");
|
||||
MODULE_INFO(livepatch, "Y");
|
||||
MODULE_INFO(klpgitrev, "22a99cfda2ebc0ca5920050d767cd88c2a573cc1");
|
6
shadow.h
Normal file
6
shadow.h
Normal file
@ -0,0 +1,6 @@
|
||||
#ifndef _KLP_SHADOW_H
|
||||
#define _KLP_SHADOW_H
|
||||
|
||||
#define KLP_SHADOW_ID(bsc, id) (((unsigned long)(bsc) << 6) | id)
|
||||
|
||||
#endif
|
3
source-timestamp
Normal file
3
source-timestamp
Normal file
@ -0,0 +1,3 @@
|
||||
2024-11-11 13:14:02 +0100
|
||||
GIT Revision: 22a99cfda2ebc0ca5920050d767cd88c2a573cc1
|
||||
GIT Branch: MICRO-6-0-RT_Update_4
|
BIN
uname_patch.tar.bz2
(Stored with Git LFS)
Normal file
BIN
uname_patch.tar.bz2
(Stored with Git LFS)
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user