store a pointer to the active interface as part of the device route
[project/netifd.git] / interface-ip.h
index f6413ee..28df093 100644 (file)
@@ -9,11 +9,11 @@ enum device_addr_flags {
        DEVADDR_INET6           = (1 << 0),
        DEVADDR_FAMILY          = DEVADDR_INET4 | DEVADDR_INET6,
 
-       /* device route (no gateway) */
-       DEVADDR_DEVICE          = (1 << 1),
-
        /* externally added address */
        DEVADDR_EXTERNAL        = (1 << 2),
+
+       /* route overrides the default interface metric */
+       DEVROUTE_METRIC         = (1 << 3)
 };
 
 union if_addr {
@@ -23,19 +23,21 @@ union if_addr {
 
 struct device_addr {
        struct vlist_node node;
-
-       enum device_addr_flags flags;
        bool enabled;
 
+       /* ipv4 only */
+       uint32_t broadcast;
+
        /* must be last */
+       enum device_addr_flags flags;
        unsigned int mask;
        union if_addr addr;
 };
 
 struct device_route {
        struct vlist_node node;
+       struct interface *iface;
 
-       enum device_addr_flags flags;
        bool enabled;
        bool keep;
 
@@ -44,6 +46,7 @@ struct device_route {
        int mtu;
 
        /* must be last */
+       enum device_addr_flags flags;
        unsigned int mask;
        union if_addr addr;
 };
@@ -73,6 +76,6 @@ void interface_ip_update_start(struct interface_ip_settings *ip);
 void interface_ip_update_complete(struct interface_ip_settings *ip);
 void interface_ip_flush(struct interface_ip_settings *ip);
 void interface_ip_set_enabled(struct interface_ip_settings *ip, bool enabled);
-
+void interface_ip_update_metric(struct interface_ip_settings *ip, int metric);
 
 #endif