X-Git-Url: http://git.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface.c;h=f5d88219ab599d278f93bf2b052726b919e0ac0b;hp=befb194af59f06b33a3e7d6aa3d22693901050d8;hb=937a95ad71e00e99bd21add761e2f810b7fb4026;hpb=d16871c7a55370174eb672edee24feade74cd37e diff --git a/interface.c b/interface.c index befb194..f5d8821 100644 --- a/interface.c +++ b/interface.c @@ -90,9 +90,7 @@ interface_event(struct interface *iface, enum interface_event ev) static void interface_flush_state(struct interface *iface) { - interface_clear_dns(iface); - vlist_flush_all(&iface->proto_addr); - vlist_flush_all(&iface->proto_route); + interface_ip_flush(&iface->proto_ip); if (iface->main_dev.dev) device_release(&iface->main_dev); } @@ -219,7 +217,8 @@ interface_cleanup(struct interface *iface) list_for_each_entry_safe(dep, tmp, &iface->users, list) interface_remove_user(dep); - interface_clear_dns(iface); + interface_ip_flush(&iface->config_ip); + interface_flush_state(iface); interface_clear_errors(iface); if (iface->main_dev.dev) device_remove_user(&iface->main_dev); @@ -274,6 +273,7 @@ interface_proto_cb(struct interface_proto_state *state, enum interface_proto_eve if (iface->state != IFS_SETUP) return; + interface_ip_set_enabled(&iface->config_ip, true); system_flush_routes(); iface->state = IFS_UP; iface->start_time = system_get_rtime(); @@ -286,6 +286,7 @@ interface_proto_cb(struct interface_proto_state *state, enum interface_proto_eve return; netifd_log_message(L_NOTICE, "Interface '%s' is now down\n", iface->name); + interface_ip_set_enabled(&iface->config_ip, false); system_flush_routes(); mark_interface_down(iface); interface_handle_config_change(iface); @@ -332,8 +333,9 @@ interface_init(struct interface *iface, const char *name, INIT_LIST_HEAD(&iface->errors); INIT_LIST_HEAD(&iface->users); INIT_LIST_HEAD(&iface->hotplug_list); - INIT_LIST_HEAD(&iface->proto_dns_search); - INIT_LIST_HEAD(&iface->proto_dns_servers); + interface_ip_init(&iface->proto_ip, iface); + interface_ip_init(&iface->config_ip, iface); + iface->config_ip.enabled = false; iface->main_dev.cb = interface_cb; iface->l3_dev = &iface->main_dev; @@ -450,6 +452,24 @@ set_config_state(struct interface *iface, enum interface_config_state s) __interface_set_down(iface, false); } +void +interface_update_start(struct interface *iface) +{ + interface_ip_update_start(&iface->proto_ip); +} + +void +interface_update_complete(struct interface *iface) +{ + struct device_route *route; + + interface_ip_update_complete(&iface->proto_ip); + vlist_for_each_element(&iface->config_ip.route, route, node) { + if (iface->l3_dev->dev) + system_add_route(iface->l3_dev->dev, route); + } +} + static void interface_change_config(struct interface *if_old, struct interface *if_new) { @@ -509,7 +529,6 @@ interface_update(struct vlist_tree *tree, struct vlist_node *node_new, D(INTERFACE, "Create interface '%s'\n", if_new->name); interface_claim_device(if_new); proto_init_interface(if_new, if_new->config); - interface_ip_init(if_new); netifd_ubus_add_interface(if_new); } }