X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface.h;h=91cffcab444522e9dde471147299d4f040451e7b;hp=6620796306363e2c5a6fb107e131d43e53c0dd17;hb=ccca61c97d460d73f29750abdf38cea20ac440f3;hpb=41842d3f91733786cb4d2bcdc6ca0c3a1a1c594b diff --git a/interface.h b/interface.h index 6620796..91cffca 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 */ @@ -52,8 +58,11 @@ struct interface { 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; + bool hotplug_dev; /* interface that layer 3 communication will go through */ struct device_user *l3_dev; @@ -90,6 +99,11 @@ void interface_set_proto_state(struct interface *iface, struct interface_proto_s 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); + + +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);