X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=c78a076293cd0dcffdcd60330f3238c8bbfd00ac;hp=ab78bf75b5da41f2a73e765b29d53769138bd4b7;hb=2674941b06c1ec67f1aff1bff9212e1372106641;hpb=09ae3bfa2ad7a3a9630fdf290b872a2d7673843f diff --git a/interface-ip.h b/interface-ip.h index ab78bf7..c78a076 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -39,6 +39,9 @@ enum device_addr_flags { /* route resides in different table */ DEVROUTE_TABLE = (1 << 7), + + /* route resides in default source-route table */ + DEVROUTE_SRCTABLE = (1 << 8), }; union if_addr { @@ -62,11 +65,13 @@ struct device_prefix { time_t valid_until; time_t preferred_until; - struct in6_addr addr; struct in6_addr excl_addr; + uint8_t excl_length; + struct in6_addr addr; uint8_t length; - uint8_t excl_length; + + char pclass[]; }; struct device_addr { @@ -96,12 +101,12 @@ struct device_route { union if_addr nexthop; int mtu; - unsigned int table; 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; union if_addr addr; }; @@ -117,7 +122,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); @@ -134,11 +139,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); -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 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);