Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/livepatching
Pull livepatching fix from Jiri Kosina: "A fix for a kernel oops in case CONFIG_DEBUG_SET_MODULE_RONX is unset (as in such case it's possible for module struct to share a page with executable text, which is currently not being handled with grace) from Josh Poimboeuf" * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/livepatching: livepatch: Fix crash with !CONFIG_DEBUG_SET_MODULE_RONX
This commit is contained in:
commit
99aaa9c64b
1 changed files with 5 additions and 4 deletions
|
@ -42,7 +42,6 @@ int klp_write_module_reloc(struct module *mod, unsigned long type,
|
|||
bool readonly;
|
||||
unsigned long val;
|
||||
unsigned long core = (unsigned long)mod->module_core;
|
||||
unsigned long core_ro_size = mod->core_ro_size;
|
||||
unsigned long core_size = mod->core_size;
|
||||
|
||||
switch (type) {
|
||||
|
@ -70,10 +69,12 @@ int klp_write_module_reloc(struct module *mod, unsigned long type,
|
|||
/* loc does not point to any symbol inside the module */
|
||||
return -EINVAL;
|
||||
|
||||
if (loc < core + core_ro_size)
|
||||
readonly = false;
|
||||
|
||||
#ifdef CONFIG_DEBUG_SET_MODULE_RONX
|
||||
if (loc < core + mod->core_ro_size)
|
||||
readonly = true;
|
||||
else
|
||||
readonly = false;
|
||||
#endif
|
||||
|
||||
/* determine if the relocation spans a page boundary */
|
||||
numpages = ((loc & PAGE_MASK) == ((loc + size) & PAGE_MASK)) ? 1 : 2;
|
||||
|
|
Loading…
Reference in a new issue