From 16cee36ff3cf1895f87368709dabd3ffd5f24e4f Mon Sep 17 00:00:00 2001 From: Steven Barth Date: Wed, 23 Oct 2013 10:26:40 +0200 Subject: Fix cleanup of interfaces --- src/config.c | 12 +++++------- src/odhcpd.h | 2 +- 2 files changed, 6 insertions(+), 8 deletions(-) (limited to 'src') diff --git a/src/config.c b/src/config.c index f008c12..6c09541 100644 --- a/src/config.c +++ b/src/config.c @@ -273,8 +273,6 @@ int config_parse_interface(void *data, size_t len, const char *name, bool overwr iface = calloc(1, sizeof(*iface)); strncpy(iface->name, name, sizeof(iface->name) - 1); list_add(&iface->head, &interfaces); - } else if (overwrite) { - clean_interface(iface); } const char *ifname = NULL; @@ -298,9 +296,6 @@ int config_parse_interface(void *data, size_t len, const char *name, bool overwr iface->inuse = true; - if (overwrite) - clean_interface(iface); - if ((c = tb[IFACE_ATTR_DYNAMICDHCP])) iface->no_dynamic_dhcp = !blobmsg_get_bool(c); @@ -503,6 +498,10 @@ void odhcpd_reload(void) free(l); } + struct interface *master = NULL, *i, *n; + list_for_each_entry(i, &interfaces, head) + clean_interface(i); + struct uci_package *dhcp = NULL; if (!uci_load(uci, "dhcp", &dhcp)) { struct uci_element *e; @@ -521,12 +520,12 @@ void odhcpd_reload(void) } } + #ifdef WITH_UBUS ubus_apply_network(); #endif // Evaluate hybrid mode for master - struct interface *master = NULL, *i, *n; list_for_each_entry(i, &interfaces, head) { if (!i->master) continue; @@ -570,7 +569,6 @@ void odhcpd_reload(void) setup_dhcpv6_interface(i, true); setup_ndp_interface(i, true); setup_dhcpv4_interface(i, true); - i->inuse = false; } else { close_interface(i); } diff --git a/src/odhcpd.h b/src/odhcpd.h index 5ae6a39..9949253 100644 --- a/src/odhcpd.h +++ b/src/odhcpd.h @@ -104,7 +104,6 @@ struct interface { int ifindex; char ifname[IF_NAMESIZE]; char name[IF_NAMESIZE]; - bool inuse; // Runtime data struct uloop_timeout timer_rs; @@ -124,6 +123,7 @@ struct interface { enum odhcpd_mode dhcpv4; // Config + bool inuse; bool external; bool master; bool ignore; -- cgit v1.2.3