X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=197bd9a5a1c7e3304c7f3e3efc5a4128f00f425b;hp=9b4f0a1d54e009038f2b6e0ef0f31f1c3c875f64;hb=HEAD;hpb=f73f11865e8601a0cb3983a6f2b2beb5ebabd14d diff --git a/interface-ip.h b/interface-ip.h index 9b4f0a1..197bd9a 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -31,11 +31,23 @@ 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), + + /* 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 { @@ -43,31 +55,64 @@ union if_addr { struct in6_addr in6; }; +struct device_prefix_assignment { + struct list_head head; + int32_t assigned; + uint8_t length; + int weight; + struct in6_addr addr; + bool enabled; + char name[]; +}; + struct device_prefix { struct vlist_node node; struct list_head head; - struct vlist_tree *assignments; + struct list_head assignments; struct interface *iface; - uint64_t avail; time_t valid_until; time_t preferred_until; + struct in6_addr excl_addr; + uint8_t excl_length; + struct in6_addr addr; uint8_t length; + + char pclass[]; }; -struct device_prefix_assignment { +struct device_route { struct vlist_node node; - struct device_prefix *prefix; - struct in6_addr addr; + struct interface *iface; + bool enabled; - uint8_t length; - char *name; + bool keep; + bool failed; + + union if_addr nexthop; + int mtu; + unsigned int type; + unsigned int proto; + 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 sourcemask; + union if_addr addr; + union if_addr source; }; struct device_addr { struct vlist_node node; bool enabled; + bool failed; + unsigned int policy_table; + + struct device_route subnet; /* ipv4 only */ uint32_t broadcast; @@ -76,6 +121,7 @@ struct device_addr { /* ipv6 only */ time_t valid_until; time_t preferred_until; + char *pclass; /* must be last */ enum device_addr_flags flags; @@ -83,21 +129,12 @@ struct device_addr { union if_addr addr; }; -struct device_route { - struct vlist_node node; - struct interface *iface; - - bool enabled; - bool keep; - - union if_addr nexthop; - 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; +struct device_source_table { + struct list_head head; + uint32_t table; + uint16_t refcount; + uint8_t v6; + uint8_t mask; union if_addr addr; }; @@ -112,7 +149,7 @@ struct dns_search_domain { 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); @@ -129,12 +166,12 @@ 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 *interface_ip_add_target_route(union if_addr *addr, bool v6, struct interface *iface); -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); + 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); #endif