kconfig: use menu_list_for_each_sym() in sym_choice_default()
authorMasahiro Yamada <masahiroy@kernel.org>
Tue, 18 Jun 2024 10:35:25 +0000 (19:35 +0900)
committerMasahiro Yamada <masahiroy@kernel.org>
Mon, 15 Jul 2024 16:08:37 +0000 (01:08 +0900)
Choices and their members are associated via the P_CHOICE property.

Currently, sym_get_choice_prop() and expr_list_for_each_sym() are
used to iterate on choice members.

Replace them with menu_for_each_sub_entry(), which achieves the same
without relying on P_CHOICE.

Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
scripts/kconfig/symbol.c

index 3d68ab8..56e7a76 100644 (file)
@@ -257,9 +257,9 @@ static void sym_calc_visibility(struct symbol *sym)
  */
 struct symbol *sym_choice_default(struct menu *choice)
 {
+       struct menu *menu;
        struct symbol *def_sym;
        struct property *prop;
-       struct expr *e;
 
        /* any of the defaults visible? */
        for_all_defaults(choice->sym, prop) {
@@ -272,10 +272,9 @@ struct symbol *sym_choice_default(struct menu *choice)
        }
 
        /* just get the first visible value */
-       prop = sym_get_choice_prop(choice->sym);
-       expr_list_for_each_sym(prop->expr, e, def_sym)
-               if (def_sym->visible != no)
-                       return def_sym;
+       menu_for_each_sub_entry(menu, choice)
+               if (menu->sym && menu->sym->visible != no)
+                       return menu->sym;
 
        /* failed to locate any defaults */
        return NULL;