X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=112c61b0d7216253ef61d1e1a5f6d34165514830;hp=2f5cf855665c023270d0914c272bf52083f0df33;hb=b8f0ce8319a43d629c8de86df6951892b7e8d813;hpb=818abd9f2f42c36a0f91ff6d29a9a635398216e0 diff --git a/interface-ip.h b/interface-ip.h index 2f5cf85..112c61b 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -1,14 +1,19 @@ #ifndef __INTERFACE_IP_H #define __INTERFACE_IP_H +#include "interface.h" + enum device_addr_flags { /* address family for routes and addresses */ - DEVADDR_INET4 = (0 << 0), - DEVADDR_INET6 = (1 << 0), - DEVADDR_FAMILY = DEVADDR_INET4 | DEVADDR_INET6, + DEVADDR_INET4 = (0 << 0), + DEVADDR_INET6 = (1 << 0), + DEVADDR_FAMILY = DEVADDR_INET4 | DEVADDR_INET6, /* device route (no gateway) */ - DEVADDR_DEVICE = (1 << 1), + DEVADDR_DEVICE = (1 << 1), + + /* externally added address */ + DEVADDR_EXTERNAL = (1 << 2), }; union if_addr { @@ -17,32 +22,60 @@ union if_addr { }; struct device_addr { - struct list_head list; - void *ctx; + struct vlist_node node; enum device_addr_flags flags; + bool enabled; + struct device *device; + + /* must be last */ unsigned int mask; union if_addr addr; }; struct device_route { - struct list_head list; - void *ctx; + struct vlist_node node; enum device_addr_flags flags; + bool enabled; + bool keep; + union if_addr nexthop; + struct device *device; + int metric; + int mtu; + + /* must be last */ unsigned int mask; union if_addr addr; - union if_addr nexthop; }; -int interface_add_address(struct interface *iface, struct device_addr *addr); -void interface_del_address(struct interface *iface, struct device_addr *addr); -void interface_del_ctx_addr(struct interface *iface, void *ctx); +struct dns_server { + struct vlist_simple_node node; + int af; + union if_addr addr; +}; + +struct dns_search_domain { + struct vlist_simple_node node; + char name[]; +}; + +extern const struct config_param_list route_attr_list; + +void interface_ip_init(struct interface_ip_settings *ip, 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); +void interface_write_resolv_conf(void); + +void interface_ip_add_route(struct interface *iface, struct blob_attr *attr, bool v6); + +void interface_ip_update_start(struct interface_ip_settings *ip); +void interface_ip_update_complete(struct interface_ip_settings *ip); +void interface_ip_flush(struct interface_ip_settings *ip); +void interface_ip_set_enabled(struct interface_ip_settings *ip, bool enabled); -int interface_add_route(struct interface *iface, struct device_route *route); -void interface_del_route(struct interface *iface, struct device_route *route); -void interface_del_all_routes(struct interface *iface); #endif