Lines Matching +full:tri +full:- +full:default +full:- +full:2
1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2002 Roman Zippel <zippel@linux-m68k.org>
44 enum symbol_type type = sym->type; in sym_get_type()
47 if (sym_is_choice_value(sym) && sym->visible == yes) in sym_get_type()
88 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_get_default_prop()
89 if (prop->visible.tri != no) in sym_get_default_prop()
100 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_get_range_prop()
101 if (prop->visible.tri != no) in sym_get_range_prop()
110 switch (sym->type) { in sym_get_range_val()
117 default: in sym_get_range_val()
120 return strtoll(sym->curr.val, NULL, base); in sym_get_range_val()
130 switch (sym->type) { in sym_validate_range()
137 default: in sym_validate_range()
143 val = strtoll(sym->curr.val, NULL, base); in sym_validate_range()
144 range_sym = prop->expr->left.sym; in sym_validate_range()
147 range_sym = prop->expr->right.sym; in sym_validate_range()
152 sym->curr.val = range_sym->curr.val; in sym_validate_range()
159 sym->flags |= SYMBOL_CHANGED; in sym_set_changed()
160 for (prop = sym->prop; prop; prop = prop->next) { in sym_set_changed()
161 if (prop->menu) in sym_set_changed()
162 prop->menu->flags |= MENU_CHANGED; in sym_set_changed()
179 tristate tri; in sym_calc_visibility() local
182 tri = no; in sym_calc_visibility()
188 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_calc_visibility()
194 if (choice_sym && sym->type == S_TRISTATE && in sym_calc_visibility()
195 prop->visible.tri == mod && choice_sym->curr.tri == yes) in sym_calc_visibility()
196 prop->visible.tri = no; in sym_calc_visibility()
198 tri = EXPR_OR(tri, prop->visible.tri); in sym_calc_visibility()
200 if (tri == mod && (sym->type != S_TRISTATE || modules_val == no)) in sym_calc_visibility()
201 tri = yes; in sym_calc_visibility()
202 if (sym->visible != tri) { in sym_calc_visibility()
203 sym->visible = tri; in sym_calc_visibility()
209 tri = yes; in sym_calc_visibility()
210 if (sym->dir_dep.expr) in sym_calc_visibility()
211 tri = expr_calc_value(sym->dir_dep.expr); in sym_calc_visibility()
212 if (tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_visibility()
213 tri = yes; in sym_calc_visibility()
214 if (sym->dir_dep.tri != tri) { in sym_calc_visibility()
215 sym->dir_dep.tri = tri; in sym_calc_visibility()
218 tri = no; in sym_calc_visibility()
219 if (sym->rev_dep.expr) in sym_calc_visibility()
220 tri = expr_calc_value(sym->rev_dep.expr); in sym_calc_visibility()
221 if (tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_visibility()
222 tri = yes; in sym_calc_visibility()
223 if (sym->rev_dep.tri != tri) { in sym_calc_visibility()
224 sym->rev_dep.tri = tri; in sym_calc_visibility()
227 tri = no; in sym_calc_visibility()
228 if (sym->implied.expr) in sym_calc_visibility()
229 tri = expr_calc_value(sym->implied.expr); in sym_calc_visibility()
230 if (tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_visibility()
231 tri = yes; in sym_calc_visibility()
232 if (sym->implied.tri != tri) { in sym_calc_visibility()
233 sym->implied.tri = tri; in sym_calc_visibility()
239 * Find the default symbol for a choice.
240 * First try the default values for the choice symbol
252 prop->visible.tri = expr_calc_value(prop->visible.expr); in sym_choice_default()
253 if (prop->visible.tri == no) in sym_choice_default()
256 if (def_sym->visible != no) in sym_choice_default()
262 expr_list_for_each_sym(prop->expr, e, def_sym) in sym_choice_default()
263 if (def_sym->visible != no) in sym_choice_default()
278 flags = sym->flags; in sym_calc_choice()
280 expr_list_for_each_sym(prop->expr, e, def_sym) { in sym_calc_choice()
282 if (def_sym->visible != no) in sym_calc_choice()
283 flags &= def_sym->flags; in sym_calc_choice()
286 sym->flags &= flags | ~SYMBOL_DEF_USER; in sym_calc_choice()
289 def_sym = sym->def[S_DEF_USER].val; in sym_calc_choice()
290 if (def_sym && def_sym->visible != no) in sym_calc_choice()
297 sym->curr.tri = no; in sym_calc_choice()
308 sym->name); in sym_warn_unmet_dep()
311 sym->dir_dep.tri == mod ? 'm' : 'n'); in sym_warn_unmet_dep()
312 expr_gstr_print(sym->dir_dep.expr, &gs); in sym_warn_unmet_dep()
315 expr_gstr_print_revdep(sym->rev_dep.expr, &gs, yes, in sym_warn_unmet_dep()
317 expr_gstr_print_revdep(sym->rev_dep.expr, &gs, mod, in sym_warn_unmet_dep()
332 if (sym->flags & SYMBOL_VALID) in sym_calc_value()
336 sym->flags & SYMBOL_NEED_SET_CHOICE_VALUES) { in sym_calc_value()
337 sym->flags &= ~SYMBOL_NEED_SET_CHOICE_VALUES; in sym_calc_value()
342 sym->flags |= SYMBOL_VALID; in sym_calc_value()
344 oldval = sym->curr; in sym_calc_value()
346 switch (sym->type) { in sym_calc_value()
356 default: in sym_calc_value()
357 sym->curr.val = sym->name; in sym_calc_value()
358 sym->curr.tri = no; in sym_calc_value()
361 sym->flags &= ~SYMBOL_WRITE; in sym_calc_value()
365 if (sym->visible != no) in sym_calc_value()
366 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
368 /* set default if recursively called */ in sym_calc_value()
369 sym->curr = newval; in sym_calc_value()
374 if (sym_is_choice_value(sym) && sym->visible == yes) { in sym_calc_value()
376 newval.tri = (prop_get_symbol(prop)->curr.val == sym) ? yes : no; in sym_calc_value()
378 if (sym->visible != no) { in sym_calc_value()
380 * if available, otherwise try the default value in sym_calc_value()
383 newval.tri = EXPR_AND(sym->def[S_DEF_USER].tri, in sym_calc_value()
384 sym->visible); in sym_calc_value()
388 if (sym->rev_dep.tri != no) in sym_calc_value()
389 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
393 newval.tri = EXPR_AND(expr_calc_value(prop->expr), in sym_calc_value()
394 prop->visible.tri); in sym_calc_value()
395 if (newval.tri != no) in sym_calc_value()
396 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
398 if (sym->implied.tri != no) { in sym_calc_value()
399 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
400 newval.tri = EXPR_OR(newval.tri, sym->implied.tri); in sym_calc_value()
401 newval.tri = EXPR_AND(newval.tri, in sym_calc_value()
402 sym->dir_dep.tri); in sym_calc_value()
406 if (sym->dir_dep.tri < sym->rev_dep.tri) in sym_calc_value()
408 newval.tri = EXPR_OR(newval.tri, sym->rev_dep.tri); in sym_calc_value()
410 if (newval.tri == mod && sym_get_type(sym) == S_BOOLEAN) in sym_calc_value()
411 newval.tri = yes; in sym_calc_value()
416 if (sym->visible != no && sym_has_value(sym)) { in sym_calc_value()
417 newval.val = sym->def[S_DEF_USER].val; in sym_calc_value()
424 sym->flags |= SYMBOL_WRITE; in sym_calc_value()
426 newval.val = ds->curr.val; in sym_calc_value()
430 default: in sym_calc_value()
434 sym->curr = newval; in sym_calc_value()
435 if (sym_is_choice(sym) && newval.tri == yes) in sym_calc_value()
436 sym->curr.val = sym_calc_choice(sym); in sym_calc_value()
439 if (memcmp(&oldval, &sym->curr, sizeof(oldval))) { in sym_calc_value()
443 modules_val = modules_sym->curr.tri; in sym_calc_value()
451 expr_list_for_each_sym(prop->expr, e, choice_sym) { in sym_calc_value()
452 if ((sym->flags & SYMBOL_WRITE) && in sym_calc_value()
453 choice_sym->visible != no) in sym_calc_value()
454 choice_sym->flags |= SYMBOL_WRITE; in sym_calc_value()
455 if (sym->flags & SYMBOL_CHANGED) in sym_calc_value()
460 if (sym->flags & SYMBOL_NO_WRITE) in sym_calc_value()
461 sym->flags &= ~SYMBOL_WRITE; in sym_calc_value()
463 if (sym->flags & SYMBOL_NEED_SET_CHOICE_VALUES) in sym_calc_value()
473 sym->flags &= ~SYMBOL_VALID; in sym_clear_all_valid()
482 if (sym->visible == no) in sym_tristate_within_range()
490 if (sym->visible <= sym->rev_dep.tri) in sym_tristate_within_range()
492 if (sym_is_choice_value(sym) && sym->visible == yes) in sym_tristate_within_range()
494 return val >= sym->rev_dep.tri && val <= sym->visible; in sym_tristate_within_range()
504 if (!(sym->flags & SYMBOL_DEF_USER)) { in sym_set_tristate_value()
505 sym->flags |= SYMBOL_DEF_USER; in sym_set_tristate_value()
517 cs->def[S_DEF_USER].val = sym; in sym_set_tristate_value()
518 cs->flags |= SYMBOL_DEF_USER; in sym_set_tristate_value()
520 for (e = prop->expr; e; e = e->left.expr) { in sym_set_tristate_value()
521 if (e->right.sym->visible != no) in sym_set_tristate_value()
522 e->right.sym->flags |= SYMBOL_DEF_USER; in sym_set_tristate_value()
526 sym->def[S_DEF_USER].tri = val; in sym_set_tristate_value()
560 switch (sym->type) { in sym_string_valid()
565 if (ch == '-') in sym_string_valid()
578 str += 2; in sym_string_valid()
594 default: in sym_string_valid()
604 switch (sym->type) { in sym_string_within_range()
614 return val >= sym_get_range_val(prop->expr->left.sym, 10) && in sym_string_within_range()
615 val <= sym_get_range_val(prop->expr->right.sym, 10); in sym_string_within_range()
623 return val >= sym_get_range_val(prop->expr->left.sym, 16) && in sym_string_within_range()
624 val <= sym_get_range_val(prop->expr->right.sym, 16); in sym_string_within_range()
636 default: in sym_string_within_range()
647 switch (sym->type) { in sym_set_string_value()
659 default: in sym_set_string_value()
666 if (!(sym->flags & SYMBOL_DEF_USER)) { in sym_set_string_value()
667 sym->flags |= SYMBOL_DEF_USER; in sym_set_string_value()
671 oldval = sym->def[S_DEF_USER].val; in sym_set_string_value()
673 if (sym->type == S_HEX && (newval[0] != '0' || (newval[1] != 'x' && newval[1] != 'X'))) { in sym_set_string_value()
674 size += 2; in sym_set_string_value()
675 sym->def[S_DEF_USER].val = val = xmalloc(size); in sym_set_string_value()
679 sym->def[S_DEF_USER].val = val = xmalloc(size); in sym_set_string_value()
691 * Find the default value associated to a symbol.
694 * If the symbol does not have any default then fallback
695 * to the fixed default values.
706 val = symbol_no.curr.tri; in sym_get_string_default()
709 /* If symbol has a default value look it up */ in sym_get_string_default()
712 switch (sym->type) { in sym_get_string_default()
716 val = EXPR_AND(expr_calc_value(prop->expr), prop->visible.tri); in sym_get_string_default()
718 default: in sym_get_string_default()
721 * where a default value is further limited by in sym_get_string_default()
727 str = (const char *)ds->curr.val; in sym_get_string_default()
733 val = EXPR_OR(val, sym->rev_dep.tri); in sym_get_string_default()
737 if (!sym_is_choice_value(sym) && modules_sym->curr.tri == no) in sym_get_string_default()
741 if (sym->type == S_BOOLEAN && val == mod) in sym_get_string_default()
744 /* adjust the default value if this symbol is implied by another */ in sym_get_string_default()
745 if (val < sym->implied.tri) in sym_get_string_default()
746 val = sym->implied.tri; in sym_get_string_default()
748 switch (sym->type) { in sym_get_string_default()
771 switch (sym->type) { in sym_get_string_value()
780 return (modules_sym->curr.tri == no) ? "n" : "m"; in sym_get_string_value()
785 default: in sym_get_string_value()
788 return (const char *)sym->curr.val; in sym_get_string_value()
793 return sym->visible > sym->rev_dep.tri; in sym_is_changeable()
821 for (symbol = symbol_hash[hash]; symbol; symbol = symbol->next) { in sym_lookup()
822 if (symbol->name && in sym_lookup()
823 !strcmp(symbol->name, name) && in sym_lookup()
824 (flags ? symbol->flags & flags in sym_lookup()
825 : !(symbol->flags & (SYMBOL_CONST|SYMBOL_CHOICE)))) in sym_lookup()
836 symbol->name = new_name; in sym_lookup()
837 symbol->type = S_UNKNOWN; in sym_lookup()
838 symbol->flags = flags; in sym_lookup()
840 symbol->next = symbol_hash[hash]; in sym_lookup()
863 for (symbol = symbol_hash[hash]; symbol; symbol = symbol->next) { in sym_find()
864 if (symbol->name && in sym_find()
865 !strcmp(symbol->name, name) && in sym_find()
866 !(symbol->flags & SYMBOL_CONST)) in sym_find()
922 * - first, symbols that match exactly
923 * - then, alphabetical sort
932 * - if matched length on symbol s1 is the length of that symbol, in sym_rel_comp()
934 * - if matched length on symbol s2 is the length of that symbol, in sym_rel_comp()
940 exact1 = (s1->eo - s1->so) == strlen(s1->sym->name); in sym_rel_comp()
941 exact2 = (s2->eo - s2->so) == strlen(s2->sym->name); in sym_rel_comp()
943 return -1; in sym_rel_comp()
948 return strcmp(s1->sym->name, s2->sym->name); in sym_rel_comp()
967 if (sym->flags & SYMBOL_CONST || !sym->name) in sym_re_search()
969 if (regexec(&re, sym->name, 1, match, 0)) in sym_re_search()
1021 check_top->next = stack; in dep_stack_insert()
1022 stack->prev = check_top; in dep_stack_insert()
1023 stack->sym = sym; in dep_stack_insert()
1029 check_top = check_top->prev; in dep_stack_remove()
1031 check_top->next = NULL; in dep_stack_remove()
1037 * the ->prev pointer to locate the bottom of the stack.
1052 for (stack = check_top; stack != NULL; stack = stack->prev) in sym_check_print_recursive()
1053 if (stack->sym == last_sym) in sym_check_print_recursive()
1060 for (; stack; stack = stack->next) { in sym_check_print_recursive()
1061 sym = stack->sym; in sym_check_print_recursive()
1062 next_sym = stack->next ? stack->next->sym : last_sym; in sym_check_print_recursive()
1063 prop = stack->prop; in sym_check_print_recursive()
1065 prop = stack->sym->prop; in sym_check_print_recursive()
1069 for (prop = sym->prop; prop; prop = prop->next) { in sym_check_print_recursive()
1070 menu = prop->menu; in sym_check_print_recursive()
1071 if (prop->menu) in sym_check_print_recursive()
1075 if (stack->sym == last_sym) in sym_check_print_recursive()
1077 prop->file->name, prop->lineno); in sym_check_print_recursive()
1081 menu->file->name, menu->lineno, in sym_check_print_recursive()
1082 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1083 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1086 menu->file->name, menu->lineno, in sym_check_print_recursive()
1087 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1088 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1089 } else if (stack->expr == &sym->dir_dep.expr) { in sym_check_print_recursive()
1091 prop->file->name, prop->lineno, in sym_check_print_recursive()
1092 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1093 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1094 } else if (stack->expr == &sym->rev_dep.expr) { in sym_check_print_recursive()
1096 prop->file->name, prop->lineno, in sym_check_print_recursive()
1097 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1098 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1099 } else if (stack->expr == &sym->implied.expr) { in sym_check_print_recursive()
1101 prop->file->name, prop->lineno, in sym_check_print_recursive()
1102 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1103 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1104 } else if (stack->expr) { in sym_check_print_recursive()
1106 prop->file->name, prop->lineno, in sym_check_print_recursive()
1107 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1108 prop_get_type_name(prop->type), in sym_check_print_recursive()
1109 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1112 prop->file->name, prop->lineno, in sym_check_print_recursive()
1113 sym->name ? sym->name : "<choice>", in sym_check_print_recursive()
1114 prop_get_type_name(prop->type), in sym_check_print_recursive()
1115 next_sym->name ? next_sym->name : "<choice>"); in sym_check_print_recursive()
1120 "For a resolution refer to Documentation/kbuild/kconfig-language.rst\n" in sym_check_print_recursive()
1134 switch (e->type) { in sym_check_expr_deps()
1137 sym = sym_check_expr_deps(e->left.expr); in sym_check_expr_deps()
1140 return sym_check_expr_deps(e->right.expr); in sym_check_expr_deps()
1142 return sym_check_expr_deps(e->left.expr); in sym_check_expr_deps()
1149 sym = sym_check_deps(e->left.sym); in sym_check_expr_deps()
1152 return sym_check_deps(e->right.sym); in sym_check_expr_deps()
1154 return sym_check_deps(e->left.sym); in sym_check_expr_deps()
1155 default: in sym_check_expr_deps()
1158 fprintf(stderr, "Oops! How to check %d?\n", e->type); in sym_check_expr_deps()
1171 stack.expr = &sym->dir_dep.expr; in sym_check_sym_deps()
1172 sym2 = sym_check_expr_deps(sym->dir_dep.expr); in sym_check_sym_deps()
1176 stack.expr = &sym->rev_dep.expr; in sym_check_sym_deps()
1177 sym2 = sym_check_expr_deps(sym->rev_dep.expr); in sym_check_sym_deps()
1181 stack.expr = &sym->implied.expr; in sym_check_sym_deps()
1182 sym2 = sym_check_expr_deps(sym->implied.expr); in sym_check_sym_deps()
1188 for (prop = sym->prop; prop; prop = prop->next) { in sym_check_sym_deps()
1189 if (prop->type == P_CHOICE || prop->type == P_SELECT || in sym_check_sym_deps()
1190 prop->type == P_IMPLY) in sym_check_sym_deps()
1193 sym2 = sym_check_expr_deps(prop->visible.expr); in sym_check_sym_deps()
1196 if (prop->type != P_DEFAULT || sym_is_choice(sym)) in sym_check_sym_deps()
1198 stack.expr = &prop->expr; in sym_check_sym_deps()
1199 sym2 = sym_check_expr_deps(prop->expr); in sym_check_sym_deps()
1221 expr_list_for_each_sym(prop->expr, e, sym) in sym_check_choice_deps()
1222 sym->flags |= (SYMBOL_CHECK | SYMBOL_CHECKED); in sym_check_choice_deps()
1224 choice->flags |= (SYMBOL_CHECK | SYMBOL_CHECKED); in sym_check_choice_deps()
1226 choice->flags &= ~SYMBOL_CHECK; in sym_check_choice_deps()
1230 expr_list_for_each_sym(prop->expr, e, sym) { in sym_check_choice_deps()
1236 expr_list_for_each_sym(prop->expr, e, sym) in sym_check_choice_deps()
1237 sym->flags &= ~SYMBOL_CHECK; in sym_check_choice_deps()
1253 if (sym->flags & SYMBOL_CHECK) { in sym_check_deps()
1257 if (sym->flags & SYMBOL_CHECKED) in sym_check_deps()
1271 sym->flags |= (SYMBOL_CHECK | SYMBOL_CHECKED); in sym_check_deps()
1273 sym->flags &= ~SYMBOL_CHECK; in sym_check_deps()
1281 if (prop->expr && (prop->expr->type == E_SYMBOL || in prop_get_symbol()
1282 prop->expr->type == E_LIST)) in prop_get_symbol()
1283 return prop->expr->left.sym; in prop_get_symbol()
1297 return "default"; in prop_get_type_name()