X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=054ed40ac7e11f1e6b159f5c53f5de289c7df3f4;hp=28df0938dd830ed5e993eb060513cf63bc405a46;hb=d7f7f002e3d168aedb5f2bc92180f5966482d7d9;hpb=0cd5498ea51d681124d713130aef7a964b30ef25 diff --git a/interface-ip.h b/interface-ip.h index 28df093..054ed40 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -1,3 +1,16 @@ +/* + * netifd - network interface daemon + * Copyright (C) 2012 Felix Fietkau + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 + * as published by the Free Software Foundation + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ #ifndef __INTERFACE_IP_H #define __INTERFACE_IP_H @@ -13,7 +26,13 @@ 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), }; union if_addr { @@ -21,12 +40,39 @@ union if_addr { struct in6_addr in6; }; +struct device_prefix { + struct vlist_node node; + struct list_head head; + struct vlist_tree *assignments; + struct interface *iface; + uint64_t avail; + time_t valid_until; + time_t preferred_until; + + struct in6_addr addr; + uint8_t length; +}; + +struct device_prefix_assignment { + struct vlist_node node; + struct device_prefix *prefix; + struct in6_addr addr; + bool enabled; + uint8_t length; + char *name; +}; + struct device_addr { struct vlist_node node; bool enabled; /* ipv4 only */ 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; @@ -63,8 +109,9 @@ struct dns_search_domain { }; extern const struct config_param_list route_attr_list; +extern struct list_head prefixes; -void interface_ip_init(struct interface_ip_settings *ip, struct interface *iface); +void interface_ip_init(struct interface *iface); void interface_add_dns_server(struct interface_ip_settings *ip, const char *str); void interface_add_dns_server_list(struct interface_ip_settings *ip, struct blob_attr *list); void interface_add_dns_search_list(struct interface_ip_settings *ip, struct blob_attr *list); @@ -78,4 +125,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); + +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); +void interface_ip_set_ula_prefix(const char *prefix); + #endif