X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=c2213fda62106fe4ece96fc8dbd19fa41aafb076;hp=054ed40ac7e11f1e6b159f5c53f5de289c7df3f4;hb=bc4a4bb127622c76085ecec7fd20448aad7bafaf;hpb=d7f7f002e3d168aedb5f2bc92180f5966482d7d9 diff --git a/interface-ip.h b/interface-ip.h index 054ed40..c2213fd 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -33,6 +33,15 @@ enum device_addr_flags { /* route automatically added by kernel */ DEVADDR_KERNEL = (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), }; union if_addr { @@ -40,26 +49,27 @@ union if_addr { struct in6_addr in6; }; +struct device_prefix_assignment { + struct list_head head; + int32_t assigned; + uint8_t length; + 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 addr; - uint8_t length; -}; + struct in6_addr excl_addr; -struct device_prefix_assignment { - struct vlist_node node; - struct device_prefix *prefix; - struct in6_addr addr; - bool enabled; uint8_t length; - char *name; + uint8_t excl_length; }; struct device_addr { @@ -88,11 +98,13 @@ struct device_route { bool keep; union if_addr nexthop; - int metric; 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 table; unsigned int mask; union if_addr addr; }; @@ -125,12 +137,13 @@ 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); -void 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); void interface_ip_set_ula_prefix(const char *prefix); +void interface_refresh_assignments(bool hint); +int interface_ip_resolve_v6_rtable(int ifindex); #endif