add prelocal table to manipulate locally destinated traffic
[project/netifd.git] / interface-ip.h
index ab78bf7..7c4a8ae 100644 (file)
@@ -39,6 +39,15 @@ enum device_addr_flags {
 
        /* route resides in different table */
        DEVROUTE_TABLE          = (1 << 7),
 
        /* route resides in different table */
        DEVROUTE_TABLE          = (1 << 7),
+
+       /* 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 {
 };
 
 union if_addr {
@@ -50,6 +59,7 @@ struct device_prefix_assignment {
        struct list_head head;
        int32_t assigned;
        uint8_t length;
        struct list_head head;
        int32_t assigned;
        uint8_t length;
+       struct in6_addr addr;
        bool enabled;
        char name[];
 };
        bool enabled;
        char name[];
 };
@@ -62,16 +72,19 @@ struct device_prefix {
        time_t valid_until;
        time_t preferred_until;
 
        time_t valid_until;
        time_t preferred_until;
 
-       struct in6_addr addr;
        struct in6_addr excl_addr;
        struct in6_addr excl_addr;
+       uint8_t excl_length;
 
 
+       struct in6_addr addr;
        uint8_t length;
        uint8_t length;
-       uint8_t excl_length;
+
+       char pclass[];
 };
 
 struct device_addr {
        struct vlist_node node;
        bool enabled;
 };
 
 struct device_addr {
        struct vlist_node node;
        bool enabled;
+       bool failed;
 
        /* ipv4 only */
        uint32_t broadcast;
 
        /* ipv4 only */
        uint32_t broadcast;
@@ -80,6 +93,7 @@ struct device_addr {
        /* ipv6 only */
        time_t valid_until;
        time_t preferred_until;
        /* ipv6 only */
        time_t valid_until;
        time_t preferred_until;
+       char *pclass;
 
        /* must be last */
        enum device_addr_flags flags;
 
        /* must be last */
        enum device_addr_flags flags;
@@ -93,16 +107,29 @@ struct device_route {
 
        bool enabled;
        bool keep;
 
        bool enabled;
        bool keep;
+       bool failed;
 
        union if_addr nexthop;
        int mtu;
 
        union if_addr nexthop;
        int mtu;
-       unsigned int table;
+       unsigned int type;
        time_t valid_until;
 
        /* must be last */
        enum device_addr_flags flags;
        int metric; // there can be multiple routes to the same target
        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 table;
        unsigned int mask;
        unsigned int mask;
+       unsigned int sourcemask;
+       union if_addr addr;
+       union if_addr source;
+};
+
+struct device_source_table {
+       struct list_head head;
+       uint32_t table;
+       uint16_t refcount;
+       uint8_t v6;
+       uint8_t mask;
        union if_addr addr;
 };
 
        union if_addr addr;
 };
 
@@ -117,7 +144,7 @@ struct dns_search_domain {
        char name[];
 };
 
        char name[];
 };
 
-extern const struct config_param_list route_attr_list;
+extern const struct uci_blob_param_list route_attr_list;
 extern struct list_head prefixes;
 
 void interface_ip_init(struct interface *iface);
 extern struct list_head prefixes;
 
 void interface_ip_init(struct interface *iface);
@@ -134,11 +161,11 @@ 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);
 
 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 *interface_ip_add_target_route(union if_addr *addr, bool v6, struct interface *iface);
 
 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 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);
+               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_ip_set_ula_prefix(const char *prefix);
 void interface_refresh_assignments(bool hint);