X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=b36c515f3d5b1ebf12dc69dd3978882360cead65;hp=c2213fda62106fe4ece96fc8dbd19fa41aafb076;hb=c8e879595400e3485b5a075797290a1061c0b04f;hpb=570302d28d18d47f095f864be161045e169b5941 diff --git a/interface-ip.h b/interface-ip.h index c2213fd..b36c515 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -65,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 { @@ -106,6 +108,17 @@ struct device_route { 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 { + struct list_head head; + uint32_t table; + uint16_t refcount; + uint8_t v6; + uint8_t mask; union if_addr addr; }; @@ -120,7 +133,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); @@ -141,9 +154,8 @@ struct interface *interface_ip_add_target_route(union if_addr *addr, bool v6, st 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); -int interface_ip_resolve_v6_rtable(int ifindex); #endif