X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fnetifd.git;a=blobdiff_plain;f=interface-ip.h;h=78f0644c2fae100e46a6de2a4c83a1693cc835b1;hp=ba7b6c826575cafe73e3cdda3c3108d38e33e7ef;hb=a4e6adc43fe206eada9dfe5b99a6cc6ac451d702;hpb=b45c5161fe4638dc229a7ae4f0c90c57962d9ec1 diff --git a/interface-ip.h b/interface-ip.h index ba7b6c8..78f0644 100644 --- a/interface-ip.h +++ b/interface-ip.h @@ -1,6 +1,8 @@ #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), @@ -23,7 +25,11 @@ struct device_addr { struct vlist_node node; enum device_addr_flags flags; + bool enabled; + + struct device *device; + /* must be last */ unsigned int mask; union if_addr addr; }; @@ -32,14 +38,44 @@ struct device_route { struct vlist_node node; enum device_addr_flags flags; + bool enabled; bool keep; - unsigned int mask; - union if_addr addr; union if_addr nexthop; struct device *device; + int metric; + int mtu; + + /* must be last */ + unsigned int mask; + union if_addr addr; }; -void interface_ip_init(struct interface *iface); +struct dns_server { + struct list_head list; + int af; + union if_addr addr; +}; + +struct dns_search_domain { + struct list_head list; + 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); + #endif