Commit 6a121588 authored by Masahiro Yamada's avatar Masahiro Yamada

kconfig: remove 'optional' property support

The 'choice' statement is primarily used to exclusively select one
option, but the 'optional' property allows all entries to be disabled.

In the following example, both A and B can be disabled simultaneously:

    choice
            prompt "choose A, B, or nothing"
            optional

    config A
            bool "A"

    config B
            bool "B"

    endchoice

You can achieve the equivalent outcome by other means.

A common solution is to add another option to guard the choice block.
In the following example, you can set ENABLE_A_B_CHOICE=n to disable
the entire choice block:

    choice
            prompt "choose A or B"
            depends on ENABLE_A_B_CHOICE

    config A
            bool "A"

    config B
            bool "B"

    endchoice

Another approach is to insert one more entry:

    choice
            prompt "choose A, B, or disable both"

    config A
            bool "A"

    config B
            bool "B"

    config DISABLE_A_AND_B
            bool "choose this to disable both A and B"

    endchoice

Some real examples are DEBUG_INFO_NONE, INITRAMFS_COMPRESSION_NONE,
LTO_NONE, etc.

The 'optional' property is even more unnecessary for a tristate choice.

Without the 'optional' property, you can disable A and B; you can set
'm' in the choice prompt, and disable A and B individually:

    choice
            prompt "choose one built-in or make them modular"

    config A
            tristate "A"

    config B
            tristate "B"

    endchoice

In conclusion, the 'optional' property was unneeded.
Signed-off-by: default avatarMasahiro Yamada <masahiroy@kernel.org>
Reviewed-by: default avatarNicolas Schier <n.schier@avm.de>
parent d9a1dab6
...@@ -410,9 +410,6 @@ to be set to 'm'. This can be used if multiple drivers for a single ...@@ -410,9 +410,6 @@ to be set to 'm'. This can be used if multiple drivers for a single
hardware exists and only a single driver can be compiled/loaded into hardware exists and only a single driver can be compiled/loaded into
the kernel, but all drivers can be compiled as modules. the kernel, but all drivers can be compiled as modules.
A choice accepts another option "optional", which allows to set the
choice to 'n' and no entry needs to be selected.
comment:: comment::
"comment" <prompt> "comment" <prompt>
......
...@@ -810,9 +810,6 @@ int conf_write_defconfig(const char *filename) ...@@ -810,9 +810,6 @@ int conf_write_defconfig(const char *filename)
/* /*
* If symbol is a choice value and equals to the * If symbol is a choice value and equals to the
* default for a choice - skip. * default for a choice - skip.
* But only if value is bool and equal to "y" and
* choice is not "optional".
* (If choice is "optional" then all values can be "n")
*/ */
if (sym_is_choice_value(sym)) { if (sym_is_choice_value(sym)) {
struct symbol *cs; struct symbol *cs;
...@@ -820,7 +817,7 @@ int conf_write_defconfig(const char *filename) ...@@ -820,7 +817,7 @@ int conf_write_defconfig(const char *filename)
cs = prop_get_symbol(sym_get_choice_prop(sym)); cs = prop_get_symbol(sym_get_choice_prop(sym));
ds = sym_choice_default(cs); ds = sym_choice_default(cs);
if (!sym_is_optional(cs) && sym == ds) { if (sym == ds) {
if ((sym->type == S_BOOLEAN) && if ((sym->type == S_BOOLEAN) &&
sym_get_tristate_value(sym) == yes) sym_get_tristate_value(sym) == yes)
continue; continue;
......
...@@ -132,7 +132,6 @@ struct symbol { ...@@ -132,7 +132,6 @@ struct symbol {
#define SYMBOL_CHECK 0x0008 /* used during dependency checking */ #define SYMBOL_CHECK 0x0008 /* used during dependency checking */
#define SYMBOL_CHOICEVAL 0x0020 /* used as a value in a choice block */ #define SYMBOL_CHOICEVAL 0x0020 /* used as a value in a choice block */
#define SYMBOL_VALID 0x0080 /* set when symbol.curr is calculated */ #define SYMBOL_VALID 0x0080 /* set when symbol.curr is calculated */
#define SYMBOL_OPTIONAL 0x0100 /* choice is optional - values can be 'n' */
#define SYMBOL_WRITE 0x0200 /* write symbol to file (KCONFIG_CONFIG) */ #define SYMBOL_WRITE 0x0200 /* write symbol to file (KCONFIG_CONFIG) */
#define SYMBOL_CHANGED 0x0400 /* ? */ #define SYMBOL_CHANGED 0x0400 /* ? */
#define SYMBOL_WRITTEN 0x0800 /* track info to avoid double-write to .config */ #define SYMBOL_WRITTEN 0x0800 /* track info to avoid double-write to .config */
......
...@@ -87,8 +87,6 @@ static const char *dbg_sym_flags(int val) ...@@ -87,8 +87,6 @@ static const char *dbg_sym_flags(int val)
strcat(buf, "choiceval/"); strcat(buf, "choiceval/");
if (val & SYMBOL_VALID) if (val & SYMBOL_VALID)
strcat(buf, "valid/"); strcat(buf, "valid/");
if (val & SYMBOL_OPTIONAL)
strcat(buf, "optional/");
if (val & SYMBOL_WRITE) if (val & SYMBOL_WRITE)
strcat(buf, "write/"); strcat(buf, "write/");
if (val & SYMBOL_CHANGED) if (val & SYMBOL_CHANGED)
......
...@@ -120,7 +120,6 @@ n [A-Za-z0-9_-] ...@@ -120,7 +120,6 @@ n [A-Za-z0-9_-]
"menuconfig" return T_MENUCONFIG; "menuconfig" return T_MENUCONFIG;
"modules" return T_MODULES; "modules" return T_MODULES;
"on" return T_ON; "on" return T_ON;
"optional" return T_OPTIONAL;
"prompt" return T_PROMPT; "prompt" return T_PROMPT;
"range" return T_RANGE; "range" return T_RANGE;
"select" return T_SELECT; "select" return T_SELECT;
......
...@@ -138,11 +138,6 @@ static inline bool sym_is_choice_value(struct symbol *sym) ...@@ -138,11 +138,6 @@ static inline bool sym_is_choice_value(struct symbol *sym)
return sym->flags & SYMBOL_CHOICEVAL ? true : false; return sym->flags & SYMBOL_CHOICEVAL ? true : false;
} }
static inline bool sym_is_optional(struct symbol *sym)
{
return sym->flags & SYMBOL_OPTIONAL ? true : false;
}
static inline bool sym_has_value(struct symbol *sym) static inline bool sym_has_value(struct symbol *sym)
{ {
return sym->flags & SYMBOL_DEF_USER ? true : false; return sym->flags & SYMBOL_DEF_USER ? true : false;
......
...@@ -593,15 +593,11 @@ static void _menu_finalize(struct menu *parent, bool inside_choice) ...@@ -593,15 +593,11 @@ static void _menu_finalize(struct menu *parent, bool inside_choice)
} }
/* /*
* For non-optional choices, add a reverse dependency (corresponding to * For choices, add a reverse dependency (corresponding to a select) of
* a select) of '<visibility> && m'. This prevents the user from * '<visibility> && m'. This prevents the user from setting the choice
* setting the choice mode to 'n' when the choice is visible. * mode to 'n' when the choice is visible.
*
* This would also work for non-choice symbols, but only non-optional
* choices clear SYMBOL_OPTIONAL as of writing. Choices are implemented
* as a type of symbol.
*/ */
if (sym && !sym_is_optional(sym) && parent->prompt) { if (sym && sym_is_choice(sym) && parent->prompt) {
sym->rev_dep.expr = expr_alloc_or(sym->rev_dep.expr, sym->rev_dep.expr = expr_alloc_or(sym->rev_dep.expr,
expr_alloc_and(parent->prompt->visible.expr, expr_alloc_and(parent->prompt->visible.expr,
expr_alloc_symbol(&symbol_mod))); expr_alloc_symbol(&symbol_mod)));
......
...@@ -69,7 +69,6 @@ struct menu *current_menu, *current_entry; ...@@ -69,7 +69,6 @@ struct menu *current_menu, *current_entry;
%token T_MODULES %token T_MODULES
%token T_ON %token T_ON
%token T_OPEN_PAREN %token T_OPEN_PAREN
%token T_OPTIONAL
%token T_PLUS_EQUAL %token T_PLUS_EQUAL
%token T_PROMPT %token T_PROMPT
%token T_RANGE %token T_RANGE
...@@ -140,7 +139,6 @@ stmt_list_in_choice: ...@@ -140,7 +139,6 @@ stmt_list_in_choice:
config_entry_start: T_CONFIG nonconst_symbol T_EOL config_entry_start: T_CONFIG nonconst_symbol T_EOL
{ {
$2->flags |= SYMBOL_OPTIONAL;
menu_add_entry($2); menu_add_entry($2);
printd(DEBUG_PARSE, "%s:%d:config %s\n", cur_filename, cur_lineno, $2->name); printd(DEBUG_PARSE, "%s:%d:config %s\n", cur_filename, cur_lineno, $2->name);
}; };
...@@ -152,7 +150,6 @@ config_stmt: config_entry_start config_option_list ...@@ -152,7 +150,6 @@ config_stmt: config_entry_start config_option_list
menuconfig_entry_start: T_MENUCONFIG nonconst_symbol T_EOL menuconfig_entry_start: T_MENUCONFIG nonconst_symbol T_EOL
{ {
$2->flags |= SYMBOL_OPTIONAL;
menu_add_entry($2); menu_add_entry($2);
printd(DEBUG_PARSE, "%s:%d:menuconfig %s\n", cur_filename, cur_lineno, $2->name); printd(DEBUG_PARSE, "%s:%d:menuconfig %s\n", cur_filename, cur_lineno, $2->name);
}; };
...@@ -272,12 +269,6 @@ choice_option: logic_type prompt_stmt_opt T_EOL ...@@ -272,12 +269,6 @@ choice_option: logic_type prompt_stmt_opt T_EOL
printd(DEBUG_PARSE, "%s:%d:type(%u)\n", cur_filename, cur_lineno, $1); printd(DEBUG_PARSE, "%s:%d:type(%u)\n", cur_filename, cur_lineno, $1);
}; };
choice_option: T_OPTIONAL T_EOL
{
current_entry->sym->flags |= SYMBOL_OPTIONAL;
printd(DEBUG_PARSE, "%s:%d:optional\n", cur_filename, cur_lineno);
};
choice_option: T_DEFAULT nonconst_symbol if_expr T_EOL choice_option: T_DEFAULT nonconst_symbol if_expr T_EOL
{ {
menu_add_symbol(P_DEFAULT, $2, $3); menu_add_symbol(P_DEFAULT, $2, $3);
......
...@@ -17,19 +17,6 @@ config BOOL_CHOICE1 ...@@ -17,19 +17,6 @@ config BOOL_CHOICE1
endchoice endchoice
choice
prompt "optional boolean choice"
optional
default OPT_BOOL_CHOICE1
config OPT_BOOL_CHOICE0
bool "choice 0"
config OPT_BOOL_CHOICE1
bool "choice 1"
endchoice
choice choice
prompt "tristate choice" prompt "tristate choice"
default TRI_CHOICE1 default TRI_CHOICE1
...@@ -41,16 +28,3 @@ config TRI_CHOICE1 ...@@ -41,16 +28,3 @@ config TRI_CHOICE1
tristate "choice 1" tristate "choice 1"
endchoice endchoice
choice
prompt "optional tristate choice"
optional
default OPT_TRI_CHOICE1
config OPT_TRI_CHOICE0
tristate "choice 0"
config OPT_TRI_CHOICE1
tristate "choice 1"
endchoice
...@@ -6,8 +6,6 @@ The handling of 'choice' is a bit complicated part in Kconfig. ...@@ -6,8 +6,6 @@ The handling of 'choice' is a bit complicated part in Kconfig.
The behavior of 'y' choice is intuitive. If choice values are tristate, The behavior of 'y' choice is intuitive. If choice values are tristate,
the choice can be 'm' where each value can be enabled independently. the choice can be 'm' where each value can be enabled independently.
Also, if a choice is marked as 'optional', the whole choice can be
invisible.
""" """
......
CONFIG_MODULES=y CONFIG_MODULES=y
# CONFIG_BOOL_CHOICE0 is not set # CONFIG_BOOL_CHOICE0 is not set
CONFIG_BOOL_CHOICE1=y CONFIG_BOOL_CHOICE1=y
# CONFIG_OPT_BOOL_CHOICE0 is not set
CONFIG_OPT_BOOL_CHOICE1=y
CONFIG_TRI_CHOICE0=m CONFIG_TRI_CHOICE0=m
CONFIG_TRI_CHOICE1=m CONFIG_TRI_CHOICE1=m
CONFIG_OPT_TRI_CHOICE0=m
CONFIG_OPT_TRI_CHOICE1=m
CONFIG_MODULES=y CONFIG_MODULES=y
# CONFIG_BOOL_CHOICE0 is not set # CONFIG_BOOL_CHOICE0 is not set
CONFIG_BOOL_CHOICE1=y CONFIG_BOOL_CHOICE1=y
# CONFIG_OPT_BOOL_CHOICE0 is not set
CONFIG_OPT_BOOL_CHOICE1=y
# CONFIG_TRI_CHOICE0 is not set # CONFIG_TRI_CHOICE0 is not set
CONFIG_TRI_CHOICE1=y CONFIG_TRI_CHOICE1=y
# CONFIG_OPT_TRI_CHOICE0 is not set
CONFIG_OPT_TRI_CHOICE1=y
...@@ -3,8 +3,6 @@ boolean choice ...@@ -3,8 +3,6 @@ boolean choice
1. choice 0 (BOOL_CHOICE0) (NEW) 1. choice 0 (BOOL_CHOICE0) (NEW)
> 2. choice 1 (BOOL_CHOICE1) (NEW) > 2. choice 1 (BOOL_CHOICE1) (NEW)
choice[1-2?]: choice[1-2?]:
optional boolean choice [N/y/?] (NEW)
tristate choice [M/y/?] (NEW) tristate choice [M/y/?] (NEW)
choice 0 (TRI_CHOICE0) [N/m/?] (NEW) choice 0 (TRI_CHOICE0) [N/m/?] (NEW)
choice 1 (TRI_CHOICE1) [N/m/?] (NEW) choice 1 (TRI_CHOICE1) [N/m/?] (NEW)
optional tristate choice [N/m/y/?] (NEW)
# CONFIG_MODULES is not set # CONFIG_MODULES is not set
CONFIG_OPT_BOOL_CHOICE0=y
...@@ -3,13 +3,7 @@ boolean choice ...@@ -3,13 +3,7 @@ boolean choice
1. choice 0 (BOOL_CHOICE0) (NEW) 1. choice 0 (BOOL_CHOICE0) (NEW)
> 2. choice 1 (BOOL_CHOICE1) (NEW) > 2. choice 1 (BOOL_CHOICE1) (NEW)
choice[1-2?]: choice[1-2?]:
optional boolean choice [Y/n/?] (NEW)
optional boolean choice
> 1. choice 0 (OPT_BOOL_CHOICE0)
2. choice 1 (OPT_BOOL_CHOICE1) (NEW)
choice[1-2?]:
tristate choice tristate choice
1. choice 0 (TRI_CHOICE0) (NEW) 1. choice 0 (TRI_CHOICE0) (NEW)
> 2. choice 1 (TRI_CHOICE1) (NEW) > 2. choice 1 (TRI_CHOICE1) (NEW)
choice[1-2?]: choice[1-2?]:
optional tristate choice [N/y/?]
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