mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-07 13:43:51 +00:00
kconfig: improve error message for recursive dependency in choice
Kconfig detects recursive dependencies in a choice block, but the error message is unclear. [Test Code] choice prompt "choose" depends on A config A bool "A" config B bool "B" endchoice [Result] Kconfig:1:error: recursive dependency detected! Kconfig:1: choice <choice> contains symbol A Kconfig:5: symbol A is part of choice <choice> For a resolution refer to Documentation/kbuild/kconfig-language.rst subsection "Kconfig recursive dependency limitations" The phrase "contains symbol A" does not accurately describe the problem. The issue is that the choice depends on A, which is a member of itself. The first if-block does not print a sensible message. Remove it. This commit improves the error message to: Kconfig:1:error: recursive dependency detected! Kconfig:1: symbol <choice> symbol is visible depending on A Kconfig:5: symbol A is part of choice <choice> For a resolution refer to Documentation/kbuild/kconfig-language.rst subsection "Kconfig recursive dependency limitations" Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
This commit is contained in:
parent
1a7d0ea83e
commit
d67624d814
@ -1106,12 +1106,7 @@ static void sym_check_print_recursive(struct symbol *last_sym)
|
|||||||
fprintf(stderr, "%s:%d:error: recursive dependency detected!\n",
|
fprintf(stderr, "%s:%d:error: recursive dependency detected!\n",
|
||||||
prop->filename, prop->lineno);
|
prop->filename, prop->lineno);
|
||||||
|
|
||||||
if (sym_is_choice(sym)) {
|
if (sym_is_choice(next_sym)) {
|
||||||
fprintf(stderr, "%s:%d:\tchoice %s contains symbol %s\n",
|
|
||||||
menu->filename, menu->lineno,
|
|
||||||
sym->name ? sym->name : "<choice>",
|
|
||||||
next_sym->name ? next_sym->name : "<choice>");
|
|
||||||
} else if (sym_is_choice(next_sym)) {
|
|
||||||
fprintf(stderr, "%s:%d:\tsymbol %s is part of choice %s\n",
|
fprintf(stderr, "%s:%d:\tsymbol %s is part of choice %s\n",
|
||||||
menu->filename, menu->lineno,
|
menu->filename, menu->lineno,
|
||||||
sym->name ? sym->name : "<choice>",
|
sym->name ? sym->name : "<choice>",
|
||||||
|
Loading…
Reference in New Issue
Block a user