X-Git-Url: http://git.openwrt.org/?a=blobdiff_plain;f=interface.h;h=0e58f69c26e0c31c62cf1b0262d664d771873db8;hb=08d8f476b6aa0d701b20cda5f706db853ade1911;hp=5b89b176e5b2f95d849e981e1d70ceb7137b63c4;hpb=c007f08413edc15805c248a8d65f075bb5fb0bdd;p=project%2Fnetifd.git diff --git a/interface.h b/interface.h index 5b89b17..0e58f69 100644 --- a/interface.h +++ b/interface.h @@ -23,6 +23,7 @@ struct interface_proto_state; enum interface_event { IFEV_DOWN, IFEV_UP, + IFEV_UP_FAILED, IFEV_UPDATE, IFEV_FREE, IFEV_RELOAD, @@ -145,6 +146,7 @@ struct interface { struct vlist_tree host_routes; int metric; + int dns_metric; unsigned int ip4table; unsigned int ip6table; @@ -154,6 +156,7 @@ struct interface { uint8_t assignment_length; int32_t assignment_hint; struct list_head assignment_classes; + int assignment_weight; /* errors/warnings while trying to bring up the interface */ struct list_head errors; @@ -182,6 +185,7 @@ void interface_set_available(struct interface *iface, bool new_state); int interface_set_up(struct interface *iface); int interface_set_down(struct interface *iface); void __interface_set_down(struct interface *iface, bool force); +int interface_renew(struct interface *iface); void interface_set_main_dev(struct interface *iface, struct device *dev); void interface_set_l3_dev(struct interface *iface, struct device *dev); @@ -198,7 +202,7 @@ void interface_add_error(struct interface *iface, const char *subsystem, int interface_add_data(struct interface *iface, const struct blob_attr *data); int interface_parse_data(struct interface *iface, const struct blob_attr *attr); -void interface_update_start(struct interface *iface); +void interface_update_start(struct interface *iface, const bool keep_old); void interface_update_complete(struct interface *iface); void interface_start_pending(void);