projects
/
openwrt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
ar71xx: add diag support for the DB120 board
[openwrt.git]
/
scripts
/
config
/
symbol.c
diff --git
a/scripts/config/symbol.c
b/scripts/config/symbol.c
index
2c1392a
..
1d718da
100644
(file)
--- a/
scripts/config/symbol.c
+++ b/
scripts/config/symbol.c
@@
-56,7
+56,6
@@
void sym_init(void)
sym = sym_lookup("ARCH", 0);
sym->type = S_STRING;
sym = sym_lookup("ARCH", 0);
sym->type = S_STRING;
- sym->flags |= SYMBOL_AUTO;
p = getenv("ARCH");
if (p)
sym_add_default(sym, p);
p = getenv("ARCH");
if (p)
sym_add_default(sym, p);
@@
-362,11
+361,14
@@
void sym_calc_value(struct symbol *sym)
sym->curr.val = sym_calc_choice(sym);
sym_validate_range(sym);
sym->curr.val = sym_calc_choice(sym);
sym_validate_range(sym);
- if (memcmp(&oldval, &sym->curr, sizeof(oldval)))
+ if (memcmp(&oldval, &sym->curr, sizeof(oldval))) {
+ sym->flags &= ~SYMBOL_VALID;
sym_set_changed(sym);
sym_set_changed(sym);
-
- if (modules_sym == sym)
- modules_val = modules_sym->curr.tri;
+ if (modules_sym == sym) {
+ sym_set_all_changed();
+ modules_val = modules_sym->curr.tri;
+ }
+ }
if (sym_is_choice(sym)) {
int flags = sym->flags & (SYMBOL_CHANGED | SYMBOL_WRITE);
if (sym_is_choice(sym)) {
int flags = sym->flags & (SYMBOL_CHANGED | SYMBOL_WRITE);
@@
-377,6
+379,9
@@
void sym_calc_value(struct symbol *sym)
sym_set_changed(e->right.sym);
}
}
sym_set_changed(e->right.sym);
}
}
+
+ if (sym->flags & SYMBOL_AUTO)
+ sym->flags &= ~SYMBOL_WRITE;
}
void sym_clear_all_valid(void)
}
void sym_clear_all_valid(void)
@@
-462,8
+467,6
@@
bool sym_set_tristate_value(struct symbol *sym, tristate val)
sym->user.tri = val;
if (oldval != val) {
sym_clear_all_valid();
sym->user.tri = val;
if (oldval != val) {
sym_clear_all_valid();
- if (sym == modules_sym)
- sym_set_all_changed();
}
return true;
}
return true;
@@
-756,6
+759,7
@@
struct symbol **sym_re_search(const char *pattern)
return NULL;
}
}
return NULL;
}
}
+ sym_calc_value(sym);
sym_arr[cnt++] = sym;
}
if (sym_arr)
sym_arr[cnt++] = sym;
}
if (sym_arr)
This page took
0.025119 seconds
and
4
git commands to generate.