CMake: bump the minimum required CMake version to 3.5
[project/netifd.git] / interface-ip.h
index 93d55eee61247fd98de68676fb197a3368e2feff..cc7efbdb84804f744f2b75d47631bff8982ef079 100644 (file)
@@ -31,8 +31,8 @@ enum device_addr_flags {
        /* route overrides the default interface mtu */
        DEVROUTE_MTU            = (1 << 4),
 
-       /* route automatically added by kernel */
-       DEVADDR_KERNEL          = (1 << 5),
+       /* route overrides the default proto type */
+       DEVROUTE_PROTO          = (1 << 5),
 
        /* address is off-link (no subnet-route) */
        DEVADDR_OFFLINK         = (1 << 6),
@@ -45,6 +45,15 @@ enum device_addr_flags {
 
        /* route is on-link */
        DEVROUTE_ONLINK         = (1 << 9),
+
+       /* route overrides the default route type */
+       DEVROUTE_TYPE           = (1 << 10),
+
+       /* neighbor mac address */
+       DEVNEIGH_MAC            = (1 << 11),
+
+       /* route specifies no device */
+       DEVROUTE_NODEV          = (1 << 12),
 };
 
 union if_addr {
@@ -56,6 +65,8 @@ struct device_prefix_assignment {
        struct list_head head;
        int32_t assigned;
        uint8_t length;
+       int weight;
+       struct in6_addr addr;
        bool enabled;
        char name[];
 };
@@ -77,46 +88,66 @@ struct device_prefix {
        char pclass[];
 };
 
-struct device_addr {
+struct device_route {
        struct vlist_node node;
+       struct interface *iface;
+
        bool enabled;
+       bool keep;
        bool failed;
 
-       /* ipv4 only */
-       uint32_t broadcast;
-       uint32_t point_to_point;
-
-       /* ipv6 only */
+       union if_addr nexthop;
+       int mtu;
+       unsigned int type;
+       unsigned int proto;
        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_route {
+struct device_neighbor {
        struct vlist_node node;
-       struct interface *iface;
 
-       bool enabled;
+       bool failed;
+       bool proxy;
        bool keep;
+       bool enabled;
+       bool router;
+
+       uint8_t macaddr[6];
+       enum device_addr_flags flags;
+       union if_addr addr;
+};
+
+struct device_addr {
+       struct vlist_node node;
+       bool enabled;
        bool failed;
+       int index;
+       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 {
@@ -140,28 +171,30 @@ struct dns_search_domain {
 };
 
 extern const struct uci_blob_param_list route_attr_list;
+extern const struct uci_blob_param_list neighbor_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);
 void interface_add_dns_server_list(struct interface_ip_settings *ip, struct blob_attr *list);
 void interface_add_dns_search_list(struct interface_ip_settings *ip, struct blob_attr *list);
-void interface_write_resolv_conf(void);
+void interface_write_resolv_conf(const char *jail);
 
 void interface_ip_add_route(struct interface *iface, struct blob_attr *attr, bool v6);
-
+void interface_ip_add_neighbor(struct interface *iface, struct blob_attr *attr, bool v6);
 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);
 
-struct interface *interface_ip_add_target_route(union if_addr *addr, bool v6, struct interface *iface);
+struct interface *interface_ip_add_target_route(union if_addr *addr, bool v6, struct interface *iface,
+                                               bool exclude);
 
 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,
                struct in6_addr *excl_addr, uint8_t excl_length, const char *pclass);
 void interface_ip_set_ula_prefix(const char *prefix);
 void interface_refresh_assignments(bool hint);
+void interface_update_prefix_delegation(struct interface_ip_settings *ip);
 
 #endif