提交 2cc499b3 编写于 作者: L Linus Torvalds

Merge branch 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip

Pull core fixes from Ingo Molnar:
 "Fix an objtool false positive plus an UP kernel memory corruption bug
  on certain configs"

* 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
  cpu/hotplug: Keep enough storage space if SMP=n to avoid array out of bounds scribble
  objtool: Fix STACK_FRAME_NON_STANDARD macro checking for function symbols
...@@ -1201,6 +1201,8 @@ static struct cpuhp_step cpuhp_bp_states[] = { ...@@ -1201,6 +1201,8 @@ static struct cpuhp_step cpuhp_bp_states[] = {
.teardown = takedown_cpu, .teardown = takedown_cpu,
.cant_stop = true, .cant_stop = true,
}, },
#else
[CPUHP_BRINGUP_CPU] = { },
#endif #endif
}; };
......
...@@ -122,10 +122,14 @@ static bool ignore_func(struct objtool_file *file, struct symbol *func) ...@@ -122,10 +122,14 @@ static bool ignore_func(struct objtool_file *file, struct symbol *func)
/* check for STACK_FRAME_NON_STANDARD */ /* check for STACK_FRAME_NON_STANDARD */
if (file->whitelist && file->whitelist->rela) if (file->whitelist && file->whitelist->rela)
list_for_each_entry(rela, &file->whitelist->rela->rela_list, list) list_for_each_entry(rela, &file->whitelist->rela->rela_list, list) {
if (rela->sym->sec == func->sec && if (rela->sym->type == STT_SECTION &&
rela->sym->sec == func->sec &&
rela->addend == func->offset) rela->addend == func->offset)
return true; return true;
if (rela->sym->type == STT_FUNC && rela->sym == func)
return true;
}
/* check if it has a context switching instruction */ /* check if it has a context switching instruction */
func_for_each_insn(file, func, insn) func_for_each_insn(file, func, insn)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册