Commit 9da8e034 authored by Miroslav Benes's avatar Miroslav Benes Committed by Greg Kroah-Hartman

livepatch: add module locking around kallsyms calls

commit 9a1bd63c upstream.

The list of loaded modules is walked through in
module_kallsyms_on_each_symbol (called by kallsyms_on_each_symbol). The
module_mutex lock should be acquired to prevent potential corruptions
in the list.

This was uncovered with new lockdep asserts in module code introduced by
the commit 0be964be ("module: Sanitize RCU usage and locking") in
recent next- trees.
Signed-off-by: default avatarMiroslav Benes <mbenes@suse.cz>
Acked-by: default avatarJosh Poimboeuf <jpoimboe@redhat.com>
Signed-off-by: default avatarJiri Kosina <jkosina@suse.cz>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c17210c3
...@@ -179,7 +179,9 @@ static int klp_find_object_symbol(const char *objname, const char *name, ...@@ -179,7 +179,9 @@ static int klp_find_object_symbol(const char *objname, const char *name,
.count = 0 .count = 0
}; };
mutex_lock(&module_mutex);
kallsyms_on_each_symbol(klp_find_callback, &args); kallsyms_on_each_symbol(klp_find_callback, &args);
mutex_unlock(&module_mutex);
if (args.count == 0) if (args.count == 0)
pr_err("symbol '%s' not found in symbol table\n", name); pr_err("symbol '%s' not found in symbol table\n", name);
...@@ -219,13 +221,19 @@ static int klp_verify_vmlinux_symbol(const char *name, unsigned long addr) ...@@ -219,13 +221,19 @@ static int klp_verify_vmlinux_symbol(const char *name, unsigned long addr)
.name = name, .name = name,
.addr = addr, .addr = addr,
}; };
int ret;
if (kallsyms_on_each_symbol(klp_verify_callback, &args)) mutex_lock(&module_mutex);
return 0; ret = kallsyms_on_each_symbol(klp_verify_callback, &args);
mutex_unlock(&module_mutex);
pr_err("symbol '%s' not found at specified address 0x%016lx, kernel mismatch?\n", if (!ret) {
name, addr); pr_err("symbol '%s' not found at specified address 0x%016lx, kernel mismatch?\n",
return -EINVAL; name, addr);
return -EINVAL;
}
return 0;
} }
static int klp_find_verify_func_addr(struct klp_object *obj, static int klp_find_verify_func_addr(struct klp_object *obj,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment