X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface.h;h=7f84060b419c45afe73e96e40681398f3f97cf6f;hp=4d53c83b2e37fd4b657b5e9aaa25bdaf78fb6836;hb=296a10e3eed1dfd5b5a96eea1309246ac34733d7;hpb=2152229c45f470a14dee33507b331ac38055e062 diff --git a/interface.h b/interface.h index 4d53c83..7f84060 100644 --- a/interface.h +++ b/interface.h @@ -33,6 +33,12 @@ struct interface_error { const char *data[]; }; +struct interface_user { + struct list_head list; + struct interface *iface; + void (*cb)(struct interface_user *dep, enum interface_event ev); +}; + /* * interface configuration */ @@ -48,9 +54,12 @@ struct interface { bool autostart; bool config_autostart; + time_t start_time; enum interface_state state; enum interface_config_state config_state; + struct list_head users; + /* main interface that the interface is bound to */ struct device_user main_dev; @@ -66,6 +75,9 @@ struct interface { struct vlist_tree proto_addr; struct vlist_tree proto_route; + struct list_head proto_dns_servers; + struct list_head proto_dns_search; + /* errors/warnings while trying to bring up the interface */ struct list_head errors; @@ -87,6 +99,9 @@ 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_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);