diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/s390/Kconfig | 3 | ||||
-rw-r--r-- | arch/s390/include/asm/livepatch.h | 43 | ||||
-rw-r--r-- | arch/x86/include/asm/livepatch.h | 4 |
3 files changed, 48 insertions, 2 deletions
diff --git a/arch/s390/Kconfig b/arch/s390/Kconfig index 373cd5badf1c..b2d7ec1669b4 100644 --- a/arch/s390/Kconfig +++ b/arch/s390/Kconfig | |||
@@ -133,6 +133,7 @@ config S390 | |||
133 | select HAVE_KPROBES | 133 | select HAVE_KPROBES |
134 | select HAVE_KRETPROBES | 134 | select HAVE_KRETPROBES |
135 | select HAVE_KVM if 64BIT | 135 | select HAVE_KVM if 64BIT |
136 | select HAVE_LIVEPATCH | ||
136 | select HAVE_MEMBLOCK | 137 | select HAVE_MEMBLOCK |
137 | select HAVE_MEMBLOCK_NODE_MAP | 138 | select HAVE_MEMBLOCK_NODE_MAP |
138 | select HAVE_MEMBLOCK_PHYS_MAP | 139 | select HAVE_MEMBLOCK_PHYS_MAP |
@@ -159,6 +160,8 @@ source "init/Kconfig" | |||
159 | 160 | ||
160 | source "kernel/Kconfig.freezer" | 161 | source "kernel/Kconfig.freezer" |
161 | 162 | ||
163 | source "kernel/livepatch/Kconfig" | ||
164 | |||
162 | menu "Processor type and features" | 165 | menu "Processor type and features" |
163 | 166 | ||
164 | config HAVE_MARCH_Z900_FEATURES | 167 | config HAVE_MARCH_Z900_FEATURES |
diff --git a/arch/s390/include/asm/livepatch.h b/arch/s390/include/asm/livepatch.h new file mode 100644 index 000000000000..7aa799134a11 --- /dev/null +++ b/arch/s390/include/asm/livepatch.h | |||
@@ -0,0 +1,43 @@ | |||
1 | /* | ||
2 | * livepatch.h - s390-specific Kernel Live Patching Core | ||
3 | * | ||
4 | * Copyright (c) 2013-2015 SUSE | ||
5 | * Authors: Jiri Kosina | ||
6 | * Vojtech Pavlik | ||
7 | * Jiri Slaby | ||
8 | */ | ||
9 | |||
10 | /* | ||
11 | * This program is free software; you can redistribute it and/or modify it | ||
12 | * under the terms of the GNU General Public License as published by the Free | ||
13 | * Software Foundation; either version 2 of the License, or (at your option) | ||
14 | * any later version. | ||
15 | */ | ||
16 | |||
17 | #ifndef ASM_LIVEPATCH_H | ||
18 | #define ASM_LIVEPATCH_H | ||
19 | |||
20 | #include <linux/module.h> | ||
21 | |||
22 | #ifdef CONFIG_LIVEPATCH | ||
23 | static inline int klp_check_compiler_support(void) | ||
24 | { | ||
25 | return 0; | ||
26 | } | ||
27 | |||
28 | static inline int klp_write_module_reloc(struct module *mod, unsigned long | ||
29 | type, unsigned long loc, unsigned long value) | ||
30 | { | ||
31 | /* not supported yet */ | ||
32 | return -ENOSYS; | ||
33 | } | ||
34 | |||
35 | static inline void klp_arch_set_pc(struct pt_regs *regs, unsigned long ip) | ||
36 | { | ||
37 | regs->psw.addr = ip; | ||
38 | } | ||
39 | #else | ||
40 | #error Live patching support is disabled; check CONFIG_LIVEPATCH | ||
41 | #endif | ||
42 | |||
43 | #endif | ||
diff --git a/arch/x86/include/asm/livepatch.h b/arch/x86/include/asm/livepatch.h index a455a53d789a..2d29197bd2fb 100644 --- a/arch/x86/include/asm/livepatch.h +++ b/arch/x86/include/asm/livepatch.h | |||
@@ -32,8 +32,8 @@ static inline int klp_check_compiler_support(void) | |||
32 | #endif | 32 | #endif |
33 | return 0; | 33 | return 0; |
34 | } | 34 | } |
35 | extern int klp_write_module_reloc(struct module *mod, unsigned long type, | 35 | int klp_write_module_reloc(struct module *mod, unsigned long type, |
36 | unsigned long loc, unsigned long value); | 36 | unsigned long loc, unsigned long value); |
37 | 37 | ||
38 | static inline void klp_arch_set_pc(struct pt_regs *regs, unsigned long ip) | 38 | static inline void klp_arch_set_pc(struct pt_regs *regs, unsigned long ip) |
39 | { | 39 | { |