do not attempt to get an interface if PROTO_FLAG_NODEV is set
[project/netifd.git] / proto.h
diff --git a/proto.h b/proto.h
index c59b976..e066b43 100644 (file)
--- a/proto.h
+++ b/proto.h
@@ -17,17 +17,18 @@ 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 (*cb)(struct interface_proto_state *, enum interface_proto_cmd cmd, bool force);
        void (*free)(struct interface_proto_state *);
 };
 
@@ -35,16 +36,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);
+int proto_apply_static_settings(struct interface_proto_state *state,
+                               struct blob_attr *attr);
 
 #endif