X-Git-Url: https://git.archive.openwrt.org/?a=blobdiff_plain;ds=sidebyside;f=interface.h;h=f7934595c301769df62a7027b5fbd046ef0e1bfd;hb=49e68df7c8e99c66084612007d89c43d9ab2a975;hp=3a0b96f93cf236d8b946ca1fe1fe97e921e8e82e;hpb=7fff5dae53f1cdc9d9d5b181fc51ee9e26aa3256;p=project%2Fnetifd.git diff --git a/interface.h b/interface.h index 3a0b96f..f793459 100644 --- a/interface.h +++ b/interface.h @@ -1,22 +1,22 @@ #ifndef __NETIFD_INTERFACE_H #define __NETIFD_INTERFACE_H +#include "device.h" +#include "config.h" + struct interface; -struct interface_proto; struct interface_proto_state; -extern struct list_head interfaces; - enum interface_event { IFEV_UP, IFEV_DOWN, }; -struct interface_proto_state { - const struct interface_proto *proto; - - int (*event)(struct interface *, struct interface_proto_state *, enum interface_event ev); - void (*free)(struct interface *, struct interface_proto_state *); +enum interface_state { + IFS_SETUP, + IFS_UP, + IFS_TEARDOWN, + IFS_DOWN, }; struct interface_error { @@ -35,10 +35,11 @@ struct interface { char name[IFNAMSIZ]; - bool up; bool active; bool autostart; + enum interface_state state; + /* main interface that the interface is bound to */ struct device_user main_dev; @@ -46,7 +47,9 @@ struct interface { struct device_user *l3_iface; /* primary protocol state */ - struct interface_proto_state *state; + struct interface_proto_state *proto; + + struct list_head address, routes; /* errors/warnings while trying to bring up the interface */ struct list_head errors; @@ -54,12 +57,16 @@ struct interface { struct ubus_object ubus; }; -struct interface *get_interface(const char *name); -struct interface *alloc_interface(const char *name); -void free_interface(struct interface *iface); +extern const struct config_param_list interface_attr_list; -int set_interface_up(struct interface *iface); -int set_interface_down(struct interface *iface); +struct interface *interface_get(const char *name); +struct interface *alloc_interface(const char *name, struct uci_section *s, struct blob_attr *attr); +void interface_free(struct interface *iface); + +void interface_set_proto_state(struct interface *iface, struct interface_proto_state *state); + +int interface_set_up(struct interface *iface); +int interface_set_down(struct interface *iface); int interface_add_link(struct interface *iface, struct device *llif); void interface_remove_link(struct interface *iface, struct device *llif); @@ -69,4 +76,14 @@ void interface_add_error(struct interface *iface, const char *subsystem, int interface_attach_bridge(struct interface *iface, struct uci_section *s); +int interface_add_address(struct interface *iface, struct device_addr *addr); +void interface_del_address(struct interface *iface, struct device_addr *addr); +void interface_del_ctx_addr(struct interface *iface, void *ctx); + +int interface_add_route(struct interface *iface, struct device_route *route); +void interface_del_route(struct interface *iface, struct device_route *route); +void interface_del_all_routes(struct interface *iface); + +void interface_start_pending(void); + #endif