X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=proto.h;h=57426bd70accdcc8f7542783bb5f3c726bc6f3a8;hp=c59b9762eff212f0e98ae7a3709eaa17cca96acb;hb=43c2934a4d3f9a3e9d7fc2a4e9a32a2bef7174ba;hpb=d06540fec1150b2046ae4929265e9d38673c5ceb diff --git a/proto.h b/proto.h index c59b976..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,17 +18,19 @@ 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 *); }; @@ -35,16 +38,21 @@ struct interface_proto_state { struct proto_handler { struct avl_node avl; + unsigned int flags; + const char *name; + const struct config_param_list *config_params; struct interface_proto_state *(*attach)(const struct proto_handler *h, - struct interface *, struct uci_section *s); + 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