X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fodhcpd.git;a=blobdiff_plain;f=src%2Fconfig.c;h=f6a5327179228f03f61a2ba4c39b83495ca766b9;hp=e33c8554fd28392435e51d0a43f448d00941a86a;hb=b61c3f98223a264de219be37720b3bee5f19cf81;hpb=74cd69a0fe942e03429582f06969d26d478e54aa diff --git a/src/config.c b/src/config.c index e33c855..f6a5327 100644 --- a/src/config.c +++ b/src/config.c @@ -276,7 +276,7 @@ int config_parse_interface(void *data, size_t len, const char *name, bool overwr const char *ifname = NULL; #ifdef WITH_UBUS - if (overwrite) + if (overwrite || !iface->ifname[0]) ifname = ubus_get_ifname(name); #endif if ((c = tb[IFACE_ATTR_IFNAME])) @@ -284,10 +284,12 @@ int config_parse_interface(void *data, size_t len, const char *name, bool overwr else if ((c = tb[IFACE_ATTR_NETWORKID])) ifname = blobmsg_get_string(c); - if (!ifname) + if (!iface->ifname[0] && !ifname) return -1; - strncpy(iface->ifname, ifname, sizeof(iface->ifname) - 1); + if (ifname) + strncpy(iface->ifname, ifname, sizeof(iface->ifname) - 1); + iface->inuse = true; if (overwrite) @@ -486,9 +488,16 @@ static int set_interface(struct uci_section *s) static volatile int do_reload = false; +void odhcpd_reload(void) +{ + uloop_cancelled = true; + do_reload = true; +} + + static void set_stop(int signal) { - uloop_end(); + uloop_cancelled = true; do_reload = (signal == SIGHUP); } @@ -580,6 +589,7 @@ void odhcpd_run(void) setup_dhcpv6_interface(i, true); setup_ndp_interface(i, true); setup_dhcpv4_interface(i, true); + i->inuse = false; } else { close_interface(i); }