device: add support for configuring device link speed/duplex
[project/netifd.git] / device.h
index f6eaf275e18ced17a4a4ab0e0b18fe313c755fa2..0968c98b4ae1de89e45ec20bb6c5c39db512b3a9 100644 (file)
--- a/device.h
+++ b/device.h
@@ -59,6 +59,9 @@ enum {
        DEV_ATTR_DROP_GRATUITOUS_ARP,
        DEV_ATTR_DROP_UNSOLICITED_NA,
        DEV_ATTR_ARP_ACCEPT,
+       DEV_ATTR_AUTH,
+       DEV_ATTR_SPEED,
+       DEV_ATTR_DUPLEX,
        __DEV_ATTR_MAX,
 };
 
@@ -82,6 +85,7 @@ struct device_type {
                struct blob_attr *attr);
        void (*config_init)(struct device *);
        enum dev_change_type (*reload)(struct device *, struct blob_attr *);
+       void (*vlan_update)(struct device *);
        void (*dump_info)(struct device *, struct blob_buf *buf);
        void (*dump_stats)(struct device *, struct blob_buf *buf);
        int (*check_state)(struct device *);
@@ -89,36 +93,38 @@ struct device_type {
 };
 
 enum {
-       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),
-       DEV_OPT_DEFAULT_MACADDR         = (1 << 10),
-       /* 1 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),
-       DEV_OPT_IP6SEGMENTROUTING       = (1 << 24),
-       DEV_OPT_DROP_V4_UNICAST_IN_L2_MULTICAST = (1 << 25),
-       DEV_OPT_DROP_V6_UNICAST_IN_L2_MULTICAST = (1 << 26),
-       DEV_OPT_DROP_GRATUITOUS_ARP     = (1 << 27),
-       DEV_OPT_DROP_UNSOLICITED_NA     = (1 << 28),
-       DEV_OPT_ARP_ACCEPT              = (1 << 29),
+       DEV_OPT_MTU                     = (1ULL << 0),
+       DEV_OPT_MACADDR                 = (1ULL << 1),
+       DEV_OPT_TXQUEUELEN              = (1ULL << 2),
+       DEV_OPT_IPV6                    = (1ULL << 3),
+       DEV_OPT_PROMISC                 = (1ULL << 4),
+       DEV_OPT_RPFILTER                = (1ULL << 5),
+       DEV_OPT_ACCEPTLOCAL             = (1ULL << 6),
+       DEV_OPT_IGMPVERSION             = (1ULL << 7),
+       DEV_OPT_MLDVERSION              = (1ULL << 8),
+       DEV_OPT_NEIGHREACHABLETIME      = (1ULL << 9),
+       DEV_OPT_DEFAULT_MACADDR         = (1ULL << 10),
+       DEV_OPT_AUTH                    = (1ULL << 11),
+       DEV_OPT_MTU6                    = (1ULL << 12),
+       DEV_OPT_DADTRANSMITS            = (1ULL << 13),
+       DEV_OPT_MULTICAST_TO_UNICAST    = (1ULL << 14),
+       DEV_OPT_MULTICAST_ROUTER        = (1ULL << 15),
+       DEV_OPT_MULTICAST               = (1ULL << 16),
+       DEV_OPT_LEARNING                = (1ULL << 17),
+       DEV_OPT_UNICAST_FLOOD           = (1ULL << 18),
+       DEV_OPT_NEIGHGCSTALETIME        = (1ULL << 19),
+       DEV_OPT_MULTICAST_FAST_LEAVE    = (1ULL << 20),
+       DEV_OPT_SENDREDIRECTS           = (1ULL << 21),
+       DEV_OPT_NEIGHLOCKTIME           = (1ULL << 22),
+       DEV_OPT_ISOLATE                 = (1ULL << 23),
+       DEV_OPT_IP6SEGMENTROUTING       = (1ULL << 24),
+       DEV_OPT_DROP_V4_UNICAST_IN_L2_MULTICAST = (1ULL << 25),
+       DEV_OPT_DROP_V6_UNICAST_IN_L2_MULTICAST = (1ULL << 26),
+       DEV_OPT_DROP_GRATUITOUS_ARP     = (1ULL << 27),
+       DEV_OPT_DROP_UNSOLICITED_NA     = (1ULL << 28),
+       DEV_OPT_ARP_ACCEPT              = (1ULL << 29),
+       DEV_OPT_SPEED                   = (1ULL << 30),
+       DEV_OPT_DUPLEX                  = (1ULL << 31),
 };
 
 /* events broadcasted to all users of a device */
@@ -134,6 +140,7 @@ enum device_event {
        DEV_EVENT_UP,
        DEV_EVENT_DOWN,
 
+       DEV_EVENT_AUTH_UP,
        DEV_EVENT_LINK_UP,
        DEV_EVENT_LINK_DOWN,
 
@@ -160,8 +167,8 @@ struct device_user {
 };
 
 struct device_settings {
-       unsigned int flags;
-       unsigned int valid_flags;
+       uint64_t flags;
+       uint64_t valid_flags;
        unsigned int mtu;
        unsigned int mtu6;
        unsigned int txqueuelen;
@@ -192,6 +199,9 @@ struct device_settings {
        bool drop_gratuitous_arp;
        bool drop_unsolicited_na;
        bool arp_accept;
+       bool auth;
+       unsigned int speed;
+       bool duplex;
 };
 
 /*
@@ -220,6 +230,7 @@ struct device {
        int active;
        /* DEV_EVENT_LINK_UP */
        bool link_active;
+       bool auth_status;
 
        bool external;
        bool disabled;
@@ -249,7 +260,7 @@ struct device {
 struct device_hotplug_ops {
        int (*prepare)(struct device *dev, struct device **bridge_dev);
        int (*add)(struct device *main, struct device *member, struct blob_attr *vlan);
-       int (*del)(struct device *main, struct device *member);
+       int (*del)(struct device *main, struct device *member, struct blob_attr *vlan);
 };
 
 enum bridge_vlan_flags {
@@ -261,6 +272,12 @@ enum bridge_vlan_flags {
 struct bridge_vlan_port {
        const char *ifname;
        uint16_t flags;
+       int8_t check;
+};
+
+struct bridge_vlan_hotplug_port {
+       struct list_head list;
+       struct bridge_vlan_port port;
 };
 
 struct bridge_vlan {
@@ -273,6 +290,7 @@ struct bridge_vlan {
 
        uint16_t vid;
        bool local;
+       bool pending;
 };
 
 extern const struct uci_blob_param_list device_attr_list;
@@ -303,7 +321,13 @@ int device_init_virtual(struct device *dev, struct device_type *type, const char
 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);
+
+struct device *__device_get(const char *name, int create, bool check_vlan);
+static inline struct device *device_get(const char *name, int create)
+{
+       return __device_get(name, create, true);
+}
+
 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);
@@ -320,10 +344,12 @@ void device_dump_status(struct blob_buf *b, struct device *dev);
 
 void device_free_unused(struct device *dev);
 
-struct device *get_vlan_device_chain(const char *ifname, bool create);
+struct device *get_vlan_device_chain(const char *ifname, int create);
 void alias_notify_device(const char *name, struct device *dev);
 struct device *device_alias_get(const char *name);
 
+void device_set_auth_status(struct device *dev, bool value);
+
 static inline void
 device_set_deferred(struct device *dev, bool value)
 {
@@ -338,6 +364,16 @@ device_set_disabled(struct device *dev, bool value)
        device_refresh_present(dev);
 }
 
+static inline bool
+device_link_active(struct device *dev)
+{
+       if (dev->settings.auth && !dev->auth_status)
+               return false;
+
+       return dev->link_active;
+}
+
 bool device_check_ip6segmentrouting(void);
+void device_hotplug_event(const char *name, bool add);
 
 #endif