wireless: add retry_setup_failed to status notification
[project/netifd.git] / interface-ip.h
index b36c515..bbef62c 100644 (file)
@@ -42,6 +42,12 @@ enum device_addr_flags {
 
        /* route resides in default source-route table */
        DEVROUTE_SRCTABLE       = (1 << 8),
+
+       /* route is on-link */
+       DEVROUTE_ONLINK         = (1 << 9),
+
+       /* route overrides the default route type */
+       DEVROUTE_TYPE           = (1 << 10),
 };
 
 union if_addr {
@@ -53,6 +59,7 @@ struct device_prefix_assignment {
        struct list_head head;
        int32_t assigned;
        uint8_t length;
+       struct in6_addr addr;
        bool enabled;
        char name[];
 };
@@ -74,43 +81,50 @@ struct device_prefix {
        char pclass[];
 };
 
-struct device_addr {
+struct device_route {
        struct vlist_node node;
-       bool enabled;
+       struct interface *iface;
 
-       /* ipv4 only */
-       uint32_t broadcast;
-       uint32_t point_to_point;
+       bool enabled;
+       bool keep;
+       bool failed;
 
-       /* ipv6 only */
+       union if_addr nexthop;
+       int mtu;
+       unsigned int type;
        time_t valid_until;
-       time_t preferred_until;
 
        /* must be last */
        enum device_addr_flags flags;
+       int metric; // there can be multiple routes to the same target
+       unsigned int table;
        unsigned int mask;
+       unsigned int sourcemask;
        union if_addr addr;
+       union if_addr source;
 };
 
-struct device_route {
+struct device_addr {
        struct vlist_node node;
-       struct interface *iface;
-
        bool enabled;
-       bool keep;
+       bool failed;
+       unsigned int policy_table;
 
-       union if_addr nexthop;
-       int mtu;
+       struct device_route subnet;
+
+       /* ipv4 only */
+       uint32_t broadcast;
+       uint32_t point_to_point;
+
+       /* ipv6 only */
        time_t valid_until;
+       time_t preferred_until;
+       char *pclass;
 
        /* must be last */
        enum device_addr_flags flags;
-       int metric; // there can be multiple routes to the same target
-       unsigned int table;
        unsigned int mask;
-       unsigned int sourcemask;
        union if_addr addr;
-       union if_addr source;
 };
 
 struct device_source_table {