X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=d206ecac67d550a87b262dda6d0e03d2619d9f44;hp=bf2cf73397f3e4c72760afc0f8a2a6142728ecae;hb=120cd39654a33401423f1b65bb19e12681a6e46f;hpb=58d2488ffe9553b908d3e10826376adeeb55d67b diff --git a/interface-ip.h b/interface-ip.h index bf2cf73..d206eca 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -1,17 +1,35 @@ +/* + * 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 +#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, - /* device route (no gateway) */ - DEVADDR_DEVICE = (1 << 1), - /* externally added address */ DEVADDR_EXTERNAL = (1 << 2), + + /* route overrides the default interface metric */ + DEVROUTE_METRIC = (1 << 3), + + /* route automatically added by kernel */ + DEVADDR_KERNEL = (1 << 4), }; union if_addr { @@ -21,24 +39,62 @@ union if_addr { struct device_addr { struct vlist_node node; + bool enabled; - enum device_addr_flags flags; + /* ipv4 only */ + uint32_t broadcast; + uint32_t point_to_point; + /* must be last */ + enum device_addr_flags flags; unsigned int mask; union if_addr addr; }; struct device_route { struct vlist_node node; + struct interface *iface; - enum device_addr_flags flags; + bool enabled; bool keep; + union if_addr nexthop; + int metric; + int mtu; + + /* must be last */ + enum device_addr_flags flags; unsigned int mask; union if_addr addr; - union if_addr nexthop; }; +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 *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); +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); #endif