diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-14 13:15:34 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-14 13:15:34 -0400 |
| commit | 9497d7380b9c450830190c75aa43b25c278bb1f9 (patch) | |
| tree | 019fe8a45676f873bf03746a671cc04bcc4512b0 /arch/s390/include/asm | |
| parent | d0bbe0dd353af9521e9d8bc5236308c677b6f62a (diff) | |
| parent | 09675bd395458543e70d19544f8046038a2fd053 (diff) | |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/livepatching
Pull livepatching updates from Jiri Kosina:
"These are mostly smaller things that got accumulated during the
development cycle. The unified solution is still being worked on and
is not mature enough for 4.1 yet.
- s390 livepatching support, from Jiri Slaby (has Ack from s390
maintainers)
- error handling simplification, from Josh Poimboeuf
- two minor code cleanups from Josh Poimboeuf and Miroslav Benes"
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/livepatching:
livepatch: add support on s390
livepatch: remove unnecessary call to klp_find_object_module()
livepatch: simplify disable error path
livepatch: remove extern specifier from header files
Diffstat (limited to 'arch/s390/include/asm')
| -rw-r--r-- | arch/s390/include/asm/livepatch.h | 43 |
1 files changed, 43 insertions, 0 deletions
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 | ||
