move l3 device tracking to interface core to enforce proper order of address/route...
[project/netifd.git] / interface.h
index 91cffca..b2ecd23 100644 (file)
@@ -39,6 +39,18 @@ struct interface_user {
        void (*cb)(struct interface_user *dep, enum interface_event ev);
 };
 
+struct interface_ip_settings {
+       struct interface *iface;
+       bool enabled;
+       bool no_defaultroute;
+
+       struct vlist_tree addr;
+       struct vlist_tree route;
+
+       struct vlist_simple_tree dns_servers;
+       struct vlist_simple_tree dns_search;
+};
+
 /*
  * interface configuration
  */
@@ -62,10 +74,9 @@ struct interface {
 
        /* 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;
+       struct device_user l3_dev;
 
        struct blob_attr *config;
 
@@ -73,11 +84,10 @@ struct interface {
        const struct proto_handler *proto_handler;
        struct interface_proto_state *proto;
 
-       struct vlist_tree proto_addr;
-       struct vlist_tree proto_route;
+       struct interface_ip_settings proto_ip;
+       struct interface_ip_settings config_ip;
 
-       struct list_head proto_dns_servers;
-       struct list_head proto_dns_search;
+       int metric;
 
        /* errors/warnings while trying to bring up the interface */
        struct list_head errors;
@@ -101,16 +111,21 @@ 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_set_main_dev(struct interface *iface, struct device *dev);
+void interface_set_l3_dev(struct interface *iface, struct device *dev);
 
 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);
+int interface_add_link(struct interface *iface, struct device *dev);
+int interface_remove_link(struct interface *iface, struct device *dev);
 
 void interface_add_error(struct interface *iface, const char *subsystem,
                         const char *code, const char **data, int n_data);
 
+void interface_update_start(struct interface *iface);
+void interface_update_complete(struct interface *iface);
+
 void interface_queue_event(struct interface *iface, enum interface_event ev);
 void interface_dequeue_event(struct interface *iface);