nterface-ip: remove superfluous iface check in interface_ip_set_enabled()
[project/netifd.git] / device.h
index dd57927..84acf52 100644 (file)
--- a/device.h
+++ b/device.h
  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  * GNU General Public License for more details.
  */
-#ifndef __LL_H
-#define __LL_H
+#ifndef __NETIFD_DEVICE_H
+#define __NETIFD_DEVICE_H
 
 #include <libubox/avl.h>
 #include <libubox/safe_list.h>
 #include <netinet/in.h>
 
 struct device;
+struct device_type;
 struct device_user;
 struct device_hotplug_ops;
+struct interface;
 
 typedef int (*device_state_cb)(struct device *, bool up);
 
 enum {
        DEV_ATTR_TYPE,
-       DEV_ATTR_IFNAME,
        DEV_ATTR_MTU,
+       DEV_ATTR_MTU6,
        DEV_ATTR_MACADDR,
        DEV_ATTR_TXQUEUELEN,
        DEV_ATTR_ENABLED,
+       DEV_ATTR_IPV6,
+       DEV_ATTR_PROMISC,
+       DEV_ATTR_RPFILTER,
+       DEV_ATTR_ACCEPTLOCAL,
+       DEV_ATTR_IGMPVERSION,
+       DEV_ATTR_MLDVERSION,
+       DEV_ATTR_NEIGHREACHABLETIME,
+       DEV_ATTR_DADTRANSMITS,
+       DEV_ATTR_MULTICAST_TO_UNICAST,
+       DEV_ATTR_MULTICAST_ROUTER,
+       DEV_ATTR_MULTICAST_FAST_LEAVE,
+       DEV_ATTR_MULTICAST,
+       DEV_ATTR_LEARNING,
+       DEV_ATTR_UNICAST_FLOOD,
+       DEV_ATTR_NEIGHGCSTALETIME,
+       DEV_ATTR_SENDREDIRECTS,
+       DEV_ATTR_NEIGHLOCKTIME,
+       DEV_ATTR_ISOLATE,
        __DEV_ATTR_MAX,
 };
 
@@ -45,9 +65,13 @@ struct device_type {
        struct list_head list;
        const char *name;
 
+       bool bridge_capability;
+       const char *name_prefix;
+
        const struct uci_blob_param_list *config_params;
 
-       struct device *(*create)(const char *name, struct blob_attr *attr);
+       struct device *(*create)(const char *name, struct device_type *devtype,
+               struct blob_attr *attr);
        void (*config_init)(struct device *);
        enum dev_change_type (*reload)(struct device *, struct blob_attr *);
        void (*dump_info)(struct device *, struct blob_buf *buf);
@@ -57,9 +81,29 @@ struct device_type {
 };
 
 enum {
-       DEV_OPT_MTU             = (1 << 0),
-       DEV_OPT_MACADDR         = (1 << 1),
-       DEV_OPT_TXQUEUELEN      = (1 << 2),
+       DEV_OPT_MTU                     = (1 << 0),
+       DEV_OPT_MACADDR                 = (1 << 1),
+       DEV_OPT_TXQUEUELEN              = (1 << 2),
+       DEV_OPT_IPV6                    = (1 << 3),
+       DEV_OPT_PROMISC                 = (1 << 4),
+       DEV_OPT_RPFILTER                = (1 << 5),
+       DEV_OPT_ACCEPTLOCAL             = (1 << 6),
+       DEV_OPT_IGMPVERSION             = (1 << 7),
+       DEV_OPT_MLDVERSION              = (1 << 8),
+       DEV_OPT_NEIGHREACHABLETIME      = (1 << 9),
+       /* 2 bit hole */
+       DEV_OPT_MTU6                    = (1 << 12),
+       DEV_OPT_DADTRANSMITS            = (1 << 13),
+       DEV_OPT_MULTICAST_TO_UNICAST    = (1 << 14),
+       DEV_OPT_MULTICAST_ROUTER        = (1 << 15),
+       DEV_OPT_MULTICAST               = (1 << 16),
+       DEV_OPT_LEARNING                = (1 << 17),
+       DEV_OPT_UNICAST_FLOOD           = (1 << 18),
+       DEV_OPT_NEIGHGCSTALETIME        = (1 << 19),
+       DEV_OPT_MULTICAST_FAST_LEAVE    = (1 << 20),
+       DEV_OPT_SENDREDIRECTS           = (1 << 21),
+       DEV_OPT_NEIGHLOCKTIME           = (1 << 22),
+       DEV_OPT_ISOLATE                 = (1 << 23),
 };
 
 /* events broadcasted to all users of a device */
@@ -78,6 +122,9 @@ enum device_event {
        DEV_EVENT_LINK_UP,
        DEV_EVENT_LINK_DOWN,
 
+       /* Topology changed (i.e. bridge member added) */
+       DEV_EVENT_TOPO_CHANGE,
+
        __DEV_EVENT_MAX
 };
 
@@ -99,9 +146,31 @@ struct device_user {
 
 struct device_settings {
        unsigned int flags;
+       unsigned int valid_flags;
        unsigned int mtu;
+       unsigned int mtu6;
        unsigned int txqueuelen;
        uint8_t macaddr[6];
+       bool ipv6;
+       bool promisc;
+       unsigned int rpfilter;
+       bool acceptlocal;
+       unsigned int igmpversion;
+       unsigned int mldversion;
+       unsigned int neigh4reachabletime;
+       unsigned int neigh6reachabletime;
+       unsigned int neigh4gcstaletime;
+       unsigned int neigh6gcstaletime;
+       int neigh4locktime;
+       unsigned int dadtransmits;
+       bool multicast_to_unicast;
+       unsigned int multicast_router;
+       bool multicast_fast_leave;
+       bool multicast;
+       bool learning;
+       bool unicast_flood;
+       bool sendredirects;
+       bool isolate;
 };
 
 /*
@@ -109,7 +178,7 @@ struct device_settings {
  * can be used to support VLANs as well
  */
 struct device {
-       const struct device_type *type;
+       struct device_type *type;
 
        struct avl_node avl;
        struct safe_list users;
@@ -121,8 +190,11 @@ struct device {
        struct blob_attr *config;
        bool config_pending;
        bool sys_present;
+       /* DEV_EVENT_ADD */
        bool present;
+       /* DEV_EVENT_UP */
        int active;
+       /* DEV_EVENT_LINK_UP */
        bool link_active;
 
        bool external;
@@ -131,7 +203,13 @@ struct device {
        bool hidden;
 
        bool current_config;
+       bool iface_config;
        bool default_config;
+       bool wireless;
+       bool wireless_ap;
+       bool wireless_isolate;
+
+       struct interface *config_iface;
 
        /* set interface up or down */
        device_state_cb set_state;
@@ -151,37 +229,40 @@ struct device_hotplug_ops {
 };
 
 extern const struct uci_blob_param_list device_attr_list;
-extern const struct device_type simple_device_type;
-extern const struct device_type bridge_device_type;
-extern const struct device_type tunnel_device_type;
-extern const struct device_type macvlan_device_type;
+extern struct device_type simple_device_type;
+extern struct device_type tunnel_device_type;
 
 void device_lock(void);
 void device_unlock(void);
 
-struct device *device_create(const char *name, const struct device_type *type,
+int device_type_add(struct device_type *devtype);
+struct device_type *device_type_get(const char *tname);
+struct device *device_create(const char *name, struct device_type *type,
                             struct blob_attr *config);
+void device_merge_settings(struct device *dev, struct device_settings *n);
 void device_init_settings(struct device *dev, struct blob_attr **tb);
 void device_init_pending(void);
 
 enum dev_change_type
-device_set_config(struct device *dev, const struct device_type *type,
-                 struct blob_attr *attr);
+device_apply_config(struct device *dev, struct device_type *type,
+                   struct blob_attr *config);
 
 void device_reset_config(void);
 void device_reset_old(void);
 
-void device_init_virtual(struct device *dev, const struct device_type *type, const char *name);
-int device_init(struct device *iface, const struct device_type *type, const char *ifname);
-void device_cleanup(struct device *iface);
+void device_init_virtual(struct device *dev, struct device_type *type, const char *name);
+int device_init(struct device *dev, struct device_type *type, const char *ifname);
+void device_cleanup(struct device *dev);
+struct device *device_find(const char *name);
 struct device *device_get(const char *name, int create);
-void device_add_user(struct device_user *dep, struct device *iface);
+void device_add_user(struct device_user *dep, struct device *dev);
 void device_remove_user(struct device_user *dep);
 void device_broadcast_event(struct device *dev, enum device_event ev);
 
 void device_set_present(struct device *dev, bool state);
 void device_set_link(struct device *dev, bool state);
 void device_set_ifindex(struct device *dev, int ifindex);
+int device_set_ifname(struct device *dev, const char *name);
 void device_refresh_present(struct device *dev);
 int device_claim(struct device_user *dep);
 void device_release(struct device_user *dep);