X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=b36c515f3d5b1ebf12dc69dd3978882360cead65;hp=ae5a63e2465ff0d7da64170d6c8b4b58c54eae05;hb=f8d894ad5974c29471cfef6679a819ab5a7e4ef8;hpb=2dc0f134aa7ec68ea7892a0d5e18d2e70b59a40e diff --git a/interface-ip.h b/interface-ip.h index ae5a63e..b36c515 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -26,7 +26,22 @@ enum device_addr_flags { DEVADDR_EXTERNAL = (1 << 2), /* route overrides the default interface metric */ - DEVROUTE_METRIC = (1 << 3) + DEVROUTE_METRIC = (1 << 3), + + /* route overrides the default interface mtu */ + DEVROUTE_MTU = (1 << 4), + + /* 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 { @@ -34,6 +49,31 @@ 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 list_head assignments; + struct interface *iface; + 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_addr { struct vlist_node node; bool enabled; @@ -42,6 +82,10 @@ struct device_addr { uint32_t broadcast; uint32_t point_to_point; + /* ipv6 only */ + time_t valid_until; + time_t preferred_until; + /* must be last */ enum device_addr_flags flags; unsigned int mask; @@ -56,12 +100,25 @@ 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; + 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; }; @@ -76,7 +133,8 @@ 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); void interface_add_dns_server(struct interface_ip_settings *ip, const char *str); @@ -92,6 +150,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); + +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, const char *pclass); +void interface_ip_set_ula_prefix(const char *prefix); +void interface_refresh_assignments(bool hint); #endif