Only update resolv.conf if changed (avoid logspam)
[project/netifd.git] / interface-ip.h
index d206eca..9b4f0a1 100644 (file)
@@ -28,8 +28,14 @@ enum device_addr_flags {
        /* route overrides the default interface metric */
        DEVROUTE_METRIC         = (1 << 3),
 
+       /* route overrides the default interface mtu */
+       DEVROUTE_MTU            = (1 << 4),
+
        /* route automatically added by kernel */
-       DEVADDR_KERNEL          = (1 << 4),
+       DEVADDR_KERNEL          = (1 << 5),
+
+       /* address is off-link (no subnet-route) */
+       DEVADDR_OFFLINK         = (1 << 6),
 };
 
 union if_addr {
@@ -37,6 +43,28 @@ union if_addr {
        struct in6_addr in6;
 };
 
+struct device_prefix {
+       struct vlist_node node;
+       struct list_head head;
+       struct vlist_tree *assignments;
+       struct interface *iface;
+       uint64_t avail;
+       time_t valid_until;
+       time_t preferred_until;
+
+       struct in6_addr addr;
+       uint8_t length;
+};
+
+struct device_prefix_assignment {
+       struct vlist_node node;
+       struct device_prefix *prefix;
+       struct in6_addr addr;
+       bool enabled;
+       uint8_t length;
+       char *name;
+};
+
 struct device_addr {
        struct vlist_node node;
        bool enabled;
@@ -45,6 +73,10 @@ struct device_addr {
        uint32_t broadcast;
        uint32_t point_to_point;
 
+       /* ipv6 only */
+       time_t valid_until;
+       time_t preferred_until;
+
        /* must be last */
        enum device_addr_flags flags;
        unsigned int mask;
@@ -59,11 +91,12 @@ struct device_route {
        bool keep;
 
        union if_addr nexthop;
-       int metric;
        int mtu;
+       time_t valid_until;
 
        /* must be last */
        enum device_addr_flags flags;
+       int metric; // there can be multiple routes to the same target
        unsigned int mask;
        union if_addr addr;
 };
@@ -80,6 +113,7 @@ struct dns_search_domain {
 };
 
 extern const struct config_param_list route_attr_list;
+extern struct list_head prefixes;
 
 void interface_ip_init(struct interface *iface);
 void interface_add_dns_server(struct interface_ip_settings *ip, const char *str);
@@ -97,4 +131,10 @@ void interface_ip_update_metric(struct interface_ip_settings *ip, int metric);
 
 struct interface *interface_ip_add_target_route(union if_addr *addr, bool v6);
 
+void interface_ip_set_prefix_assignment(struct device_prefix *prefix,
+               struct interface *iface, uint8_t length);
+struct device_prefix* interface_ip_add_device_prefix(struct interface *iface,
+               struct in6_addr *addr, uint8_t length, time_t valid_until, time_t preferred_until);
+void interface_ip_set_ula_prefix(const char *prefix);
+
 #endif