X-Git-Url: http://git.archive.openwrt.org/?a=blobdiff_plain;f=interface.h;h=f0b26f5405da0addfbe20f7788e6a8258f5e3012;hb=a609b5e8f39b132ff72476761add46d263c4147f;hp=8a009004f27e45f3dc0646c4e2811ce032f12869;hpb=d16871c7a55370174eb672edee24feade74cd37e;p=project%2Fnetifd.git diff --git a/interface.h b/interface.h index 8a00900..f0b26f5 100644 --- a/interface.h +++ b/interface.h @@ -39,6 +39,18 @@ struct interface_user { void (*cb)(struct interface_user *dep, enum interface_event ev); }; +struct interface_ip_settings { + struct interface *iface; + bool enabled; + bool no_defaultroute; + + struct vlist_tree addr; + struct vlist_tree route; + + struct vlist_simple_tree dns_servers; + struct vlist_simple_tree dns_search; +}; + /* * interface configuration */ @@ -72,11 +84,10 @@ struct interface { const struct proto_handler *proto_handler; struct interface_proto_state *proto; - struct vlist_tree proto_addr; - struct vlist_tree proto_route; + struct interface_ip_settings proto_ip; + struct interface_ip_settings config_ip; - struct list_head proto_dns_servers; - struct list_head proto_dns_search; + int metric; /* errors/warnings while trying to bring up the interface */ struct list_head errors; @@ -104,12 +115,15 @@ void __interface_set_down(struct interface *iface, bool force); void interface_add_user(struct interface_user *dep, struct interface *iface); void interface_remove_user(struct interface_user *dep); -int interface_add_link(struct interface *iface, struct device *llif); -void interface_remove_link(struct interface *iface, struct device *llif); +int interface_add_link(struct interface *iface, struct device *dev); +int interface_remove_link(struct interface *iface, struct device *dev); void interface_add_error(struct interface *iface, const char *subsystem, const char *code, const char **data, int n_data); +void interface_update_start(struct interface *iface); +void interface_update_complete(struct interface *iface); + void interface_queue_event(struct interface *iface, enum interface_event ev); void interface_dequeue_event(struct interface *iface);