X-Git-Url: http://git.ozlabs.org/?a=blobdiff_plain;f=discover%2Fnetwork.c;h=2b7e94cbbdad0a4987cb7cb54d820a2df8f0d3dc;hb=71dfb52e615d66c0ed595f0c3b0f406deb959b63;hp=c300f3dc7719619aa6092df5b476837ff8177b74;hpb=a984595cfb4910ba6f464c69c316f1613f10f894;p=petitboot diff --git a/discover/network.c b/discover/network.c index c300f3d..2b7e94c 100644 --- a/discover/network.c +++ b/discover/network.c @@ -181,6 +181,15 @@ static int interface_change(struct interface *interface, bool up) process_release(interface->udhcpc_process); } + if (!up) { + rc = process_run_simple(interface, pb_system_apps.ip, + "address", "flush", "dev", interface->name, + NULL); + if (rc) + pb_log("failed to flush addresses from interface %s\n", + interface->name); + } + rc = process_run_simple(interface, pb_system_apps.ip, "link", "set", interface->name, statestr, NULL); if (rc) { @@ -533,7 +542,7 @@ static void network_init_dns(struct network *network) buf = talloc_realloc(network, buf, char, len + dns_conf_len + 1); memcpy(buf + len, dns_conf, dns_conf_len); len += dns_conf_len; - buf[len - 1] = '\0'; + buf[len] = '\0'; modified = true; talloc_free(dns_conf); @@ -584,7 +593,6 @@ err: return NULL; } - int network_shutdown(struct network *network) { struct interface *interface;