X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=proto.h;h=57426bd70accdcc8f7542783bb5f3c726bc6f3a8;hp=332745ced3e9e42cfb0159508b0c702b0e7273c4;hb=986c4a1434cc61d2de560690ecc0d532a157d40a;hpb=dca8c7133b1db463f6ae71ccc6d34cd12735daef diff --git a/proto.h b/proto.h index 332745c..57426bd 100644 --- a/proto.h +++ b/proto.h @@ -8,6 +8,7 @@ struct proto_handler; enum interface_proto_event { IFPEV_UP, IFPEV_DOWN, + IFPEV_LINK_LOST, }; enum interface_proto_cmd { @@ -17,35 +18,41 @@ enum interface_proto_cmd { enum { PROTO_FLAG_IMMEDIATE = (1 << 0), + PROTO_FLAG_NODEV = (1 << 1), }; struct interface_proto_state { + const struct proto_handler *handler; struct interface *iface; - unsigned int flags; /* filled in by the protocol user */ void (*proto_event)(struct interface_proto_state *, enum interface_proto_event ev); /* filled in by the protocol handler */ - int (*handler)(struct interface_proto_state *, enum interface_proto_cmd cmd, bool force); + int (*notify)(struct interface_proto_state *, struct blob_attr *data); + int (*cb)(struct interface_proto_state *, enum interface_proto_cmd cmd, bool force); void (*free)(struct interface_proto_state *); }; -typedef struct interface_proto_state * - (*proto_attach_cb)(const struct proto_handler *h, struct interface *, - struct uci_section *s); struct proto_handler { struct avl_node avl; + unsigned int flags; + const char *name; - proto_attach_cb attach; + const struct config_param_list *config_params; + + struct interface_proto_state *(*attach)(const struct proto_handler *h, + struct interface *iface, struct blob_attr *attr); }; void add_proto_handler(struct proto_handler *p); -void proto_init_interface(struct interface *iface, struct uci_section *s); +void proto_init_interface(struct interface *iface, struct blob_attr *attr); void proto_attach_interface(struct interface *iface, const char *proto_name); int interface_proto_event(struct interface_proto_state *proto, enum interface_proto_cmd cmd, bool force); +struct device_addr *proto_parse_ip_addr_string(const char *str, bool v6, int mask); +unsigned int parse_netmask_string(const char *str, bool v6); #endif